2020-02-29 C++提高编程07-基本框架

3.8 set/multiset容器

3.8.1 set基本概念

特点:所有元素在插入时自动被排序

本质:set/multiset属于关联式容器,底层结构是用二叉树实现

set/multiset区别:

set 不允许容器中有重复元素

multiset 允许容器中有重复元素

3.8.2 set构造和赋值

构造函数:

set<T> st;

set(const set &st);

赋值:

set &operator=(const set &st);

3.8.3 set大小和交换

函数原型:

size();

empty();

swap(st);//交换两个集合容器

注意:不支持resize

3.8.4 set插入和删除

函数原型:

1 insert(elem);

2 clear();

3 erase(pos);//迭代器

4 erase(beg,end);//区间

5 erase(elem);

3.8.5 set查找和统计

函数原型:

find(key);//查找key是否存在,若存在,返回该键的元素的迭代器;若不存在,返回set.end();

count(key);//统计key的元素个数

示例:

//查找

set<int>::iterator pos = s.find(300);

if (pos != s.end())

{

cout << "find it :" << *pos << endl;

}

else

{

cout << "can not find it\n";

}

//统计

//对于set而言 统计结果只有0和1

int num = s.count(30);

cout << "num= " << num <<endl;

3.8.6 set和multiset区别

区别:

1 set不可以插入重复数据 而multiset可以

2 set插入数据的同时会返回插入结果,表示插入是否成功

(返回一个pair<set<int>::iterator,bool>的数据类型)

3 multiset不会检测数据 因此可以插入重复数据

示例:

void test03()

{

set<int> s;

pair<set<int>::iterator, bool> ret = s.insert(10);

if (ret.second)

cout << "insert succeed\n";

else

cout << "insert failed\n";

  ret = s.insert(10);

  if (ret.second)//返回true代表插入成功

  cout << "insert succeed\n";

  else

  cout << "insert failed\n";

  multiset<int> ms;

  ms.insert(10);

  ms.insert(10);

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

  {

  cout << *it << " ";

  }

  cout << endl; 

}

3.8.7 pair对组创建

功能描述:成对出现的数据,利用对组可以返回两个数据

两种创建方式:

pair<T,T> p(value1,value2);

pair<T,T> p = make_pair(value1,value2);

3.8.8 set容器排序

set容器默认规则从小到大,如何改变排序规则?

--利用仿函数,可以改变排序规则

两种情况:1 内置类型 2 自定义类型

示例1:

//set容器排序 --存放内置数据类型

//写一个类型

class myCompare

{

public:

//返回值bool类型 重载的符号是()

//传入参数类型依情况而定

bool operator()(int v1, int v2)

{

return v1 > v2;

}

};

void test05()

{

//set容器在插入数据之后 就改不了数据顺序了

//必须在插入数据之前指定排序规则

//在其模板参数列表中要写一个仿函数 指定其规则

//在插数据之前 改变排序规则 降序

//放置类型

set<int,myCompare> s2;

s2.insert(10);

s2.insert(40);

s2.insert(50);

s2.insert(20);

s2.insert(30);

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

{

cout <<*it << " ";

}

cout << endl;

示例2:

//set容器排序 --存放自定义数据类型

class Person

{

public:

friend ostream &operator<<(ostream &os, Person p);

Person(string name, int age)

{

this->m_Name = name;

this->m_Age = age;

}

string m_Name;

int m_Age;

};

ostream &operator<<(ostream &os, Person p)

{

os << p.m_Name << "  " << p.m_Age;

return os;

}

//仿函数

class comparePerson

{

public:

bool operator()(const Person &p1, const Person &p2)

{

//按照年龄降序

return p1.m_Age > p2.m_Age;

}

};

void test06()

{

//自定义数据类型 必须指定排序规则 才能插入数据

set<Person,comparePerson> s;

Person p1("Mike", 20);

Person p2("John", 10);

Person p3("Mary", 30);

Person p4("Boob", 40);

//直接插入时 会报错

//由于不知道排序规则

s.insert(p1);

s.insert(p2);

s.insert(p3);

s.insert(p4);

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

{

cout << *it << endl;

}

}


注意:存在问题 --当年龄相同时 插入失败

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