C++ STL 队列 queue & stack &list &set

queue是队列(没有迭代器,就是说,不能用迭代器的iterator进行遍历)

首先加入:

#include<queue>

void printDeque(deque& q){

for (int i = 0; i < q.size(); i++){

cout << q[i] << endl;

}

}

void main(){

queue<int> q;

q.push(78);

q.push(18);

q.push(20);

q.push(33);

q.pop();

while (!q.empty())

{

   int tmp = q.front();

   cout << tmp << endl;

   q.pop();

}

   system("pause");

}

push就是依次添加数据 ,pop就是清除第一个数据

//q.front();  首位的数据

//q.back();  末位的数据


最大优先级排列,就是说,在这个队列中,是按从大到小排列的,而不是按加入的先后顺序排列的

这其实就是另一种queue,所以也需要另外引用

#include<functional>

void main(){

//默认 最大值优先级

priority_queuep<int>q1;

pq1.push(12);

pq1.push(3);

pq1.push(40);

pq1.push(15);

while (!pq1.empty()){

int tmp = pq1.top();

cout << tmp << endl;

pq1.pop();

}

cout << "----------" << endl;

//最小值优先级队列

priority_queue<int,vector<int>, greater<int>> pq2;

pq2.push(12);

pq2.push(3);

pq2.push(40);

pq2.push(15);

while (!pq2.empty())

{

int tmp = pq2.top();

cout << tmp << endl;

pq2.pop();

}

system("pause");

}

priority_queuepq1; 这样就申明了一个最值优化,默认为最大,int tmp = pq1.top();就是找出最大值! 最小值也是同样的道理

再在讲讲stack,就是栈队列,栈队列就一句话,单向管,先进,后出

依然先引入

#include<stack>

void main(){

stack<int> s;

for (int i = 0; i < 10; i++)

{

s.push(i+1);

}

while (!s.empty())

{

   int tmp = s.top();

   cout << tmp << endl;

   s.pop();

}

   system("pause");

  }

最终的打印结果是:10 9 8 .... 1 符合,先进后出的原则

下面加的就是最常用的 list了! list是有迭代器的!既支持迭代器遍历!

#include<list>

list跟双向数组很像很像了!!很多方法都是类同的

void printList(list& lst){

//迭代器//没有重载“<”运算符

for (list::iterator it = lst.begin(); it != lst.end(); it++)

{

cout << *it << endl;

}

}

//基本操作

void main(){

list<int>lst;

for (int i = 0; i < 10; i++){

//尾部插入元素

lst.push_back(i);

}


list::iterator it = lst.begin();

it++;

cout << *it << endl;

//it = it + 3; 注意:不支持随机访问 还是因为没有重载运算符

printList(lst);

system("pause");

}

//还可以头部插入元素

lst.push_front(80);

lst.push_front(90);

总之,真的就跟双向数组一模一样的,但是犹豫没有重定向运算符,故是不能支持指针+3之类的这种操作。这样造成的后果是,不能随机访问,比如在list中,就不能访问list[5] 这个元素,而要不停的 it++ ,也是麻烦,但数组就可以直接访问!

下面是一些常用方法

//尾部插入元素

lst.push_back(10);

list<int>::iterator it = lst.begin();

//删除

it++;

//删除第二个元素

//lst.erase(it);

//删除区间(已经被删除了元素不能再删除)

list<int>::iterator it_begin = lst.begin();list::iterator it_end = lst.begin();

it_end++;

it_end++;

it_end++;

lst.erase(it_begin, it_end);

//直接根据内容删除元素

lst.remove(5);

从上面可以看出

//list插入(应用:频繁的修改)

//vector(应用:随机访问v[100])

1号位参入元素

list::iterator it = lst.begin();

it++;

lst.insert(it, 100);


开始讲set!!

//set 元素唯一 默认从小到大 并且set元素是有迭代器

#include<set>


void printSet(set&s){

for (set<int>::iterator it = s.begin(); it != s.end(); it++)

   {

         cout << *it << endl;

   }

}

void main(){

sets;

//添加元素

for (int i = 0; i < 10; i++){

s.insert(i+1);

}

s.insert(20);

s.insert(15);

s.insert(15);

//删除

set::iterator it = s.begin();

it++;

s.erase(it);

printSet(s);

system("pause");

}

//元素按照从大到小排列 跟那个queue模式类似

#include<functional>

void main(){

set<int,greater<int>>s;

s.insert(10);

s.insert(5);

s.insert(20);

s.insert(99);

for (set>::iterator it = s.begin(); it != s.end(); it++)

{

cout << *it << endl;

}

system("pause");

}

下面举一个例子! 利用MAP自定义排序规则!

class Teacher{

public:Teacher(char* name, int age){

this->name = name;

this->age = age;

}

void print(){

cout << name << "," << age << endl;

}

public:char* name;int age;

};

//自定义排序规则//仿函数

struct MyAgeSorter{

bool operator()(const Teacher &left, const Teacher &right){

return left.age < right.age;

}

};

void main(){

set<Teacher,MyAgeSorter>s;

s.insert(Teacher("jack",18));

s.insert(Teacher("rose", 20));

s.insert(Teacher("jason", 22));

s.insert(Teacher("alan", 5));

//s.insert(Teacher("jimy", 5)); //不会插入

for (set::iterator it = s.begin(); it != s.end(); it++)

{

cout << (*it).name << "," << (*it).age << endl;

}

system("pause");

}

这里就自定义了一个MAP的排序规则 MyAgeSorter

这样就会按这个排序规则进行排序了!

//小于4的元素指针

set<int>::iterator s_4 = s.lower_bound(4); 

//cout << *s_4 << endl;

//大于4的元素指针

set<int>::iterator s_5 = s.upper_bound(4);

//cout << *s_5 << endl;

//一次性获取等于4的元素指针,和大于4的元素指针BasicNameValuePairpair::iterator, set::iterator> p = s.equal_range(4);

cout << *p.first << endl;

cout << *p.second << endl;

前面说了,set是不允许有重复值的,要是需要有重复值

可以用:

multiset<int>s;

最后一种!MAP ,key-value类型!

#include<map>

写法有很多,现在讲一种常用的

map<int,string>map1;

map1.insert(pair(1,"jack"));

map1.insert(pair(2, "rose"));

//遍历输出

for (map<int,string>::iterator it = map1.begin(); it != map1.end(); it++)

{

cout << it->first << "," << it->second << endl;

}

first  second 就代表的key value;

删除:

map::iterator it = map1.begin();

it++;

map1.erase(it);

在map中,是可以一对多的,一个key 对应多个 value,当然,跟set类型,这里就要用到multimap

class Employee

{

   public:

   Employee(char* name,int age)

{

   this->name = name;

   this->age = age;

 }

   public:

   char* name;

   int age;

};

void main(){

multima<string,Employee>pmap1;

//开发部

map1.insert(make_pair("开发", Employee("搁浅", 20)));

map1.insert(make_pair("开发", Employee("彪哥", 20)));

//财务

map1.insert(make_pair("财务", Employee("小颖", 16)));

map1.insert(make_pair("财务", Employee("rose", 20)));//销售map1.insert(make_pair("销售", Employee("阿呆", 30)));

map1.insert(make_pair("销售", Employee("呵呵", 30)));

//遍历输出

for (multimap<string,Employee>::iterator it = map1.begin(); it != map1.end(); it++){

cout << it->first << "," << it->second.name  << "," << it->second.age << endl;

}cout << "----------------" << endl;

//只获取“财务”部的员工//获取“财务部”员工的个数,key对应的value的个数

int num = map1.count("财务");

multimap<string,Employee>::iterator it = map1.find("财务");

int c = 0; 

//控制循环的次数

while (it != map1.end() && c < num)

{

cout << it->first << "," << it->second.name << "," << it->second.age << endl;

it++;

c++;

}

system("pause");

}

这样就实现了一对多

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容