【C++】set/multiset/map/multimap
admin
2024-03-18 06:08:37
0

文章目录

  • 一、set/multiset (集合)
    • 1 set概念(自动排序、底层红黑树)
    • 2 set构造和赋值(默认、拷贝、=赋值)
    • 3 set大小和交换(size、empty、swap)
    • 4 set插入和删除(s.insert()、erase、clear)
    • 5 set查找和统计(find、count)
    • 6 set和multiset区别
    • 7 pair对组创建
      • 7.1 用pair<int,int>建立优先队列(小根堆)
    • 8 set排序 (默认从小到大,利用仿函数改变排序规则)
  • 二、map/ multimap(映射表)
    • 1 map概念(根据元素键值自动排序)
    • 2 map构造和赋值(默认、拷贝、=赋值)
    • 3 map大小和交换 (size、empty、swap)
    • 4 map插入和删除(insert、erase、clear)
    • 5 map查找和统计(find、count)
    • 6 map排序 (默认排序 按照key值 从小到大排序)

一、set/multiset (集合)

1 set概念(自动排序、底层红黑树)

  • 所有元素都会在插入时自动被排序(关联式容器)
  • set/multiset属于关联式容器,底层结构是用红黑树实现。

set和multiset区别:

  • set不允许容器中有重复的元素(插入重复元素进行忽略处理)
  • multiset允许容器中有重复的元素
set s;//创建一个int型的set集合 
s.insert(1); // 返回插入的位置和插入成功与否(返回pair类型)
s.insert(8);
s.insert(3);
s.insert(1);//因为前面插入了1,所以这行代码会被忽略 

2 set构造和赋值(默认、拷贝、=赋值)

//构造:
set s1;            //默认构造函数:
set s2(s1);       //拷贝构造函数//赋值:
s3 = s2;         //重载等号操作符

总结:

  • set容器插入数据时用 s1.insert();
#include void printSet(set & s)
{for (set::iterator it = s.begin(); it != s.end(); it++){cout << *it << " ";}cout << endl;
}//set容器构造和赋值
void test01()
{set s1;s1.insert(10);s1.insert(30);s1.insert(30);s1.insert(20);s1.insert(40);//set容器特点 ,所有元素插入自动排序//set不允许插入重复的值printSet(s1);//拷贝构造sets2(s1);printSet(s2);//赋值sets3;s3 = s2;printSet(s3);
}int main() 
{test01();system("pause");return 0;
}

3 set大小和交换(size、empty、swap)

  • 不允许重新指定大小。
s1.size()             //返回容器中元素的数目
s1.empty()            //判断容器是否为空
s1.swap(s2);          //交换两个集合容器size//s1.resize();   //不能指定大小

4 set插入和删除(s.insert()、erase、clear)

s1.insert(10);                   //在容器中插入元素,返回 pair 类型s1.erase(s1.begin());            //删除pos迭代器所指的元素,返回下一个元素的迭代器。
s1.erase(s1.begin(), s1.end());  //删除区间[beg,end)的所有元素 ,返回下一个元素的迭代器。
s1.erase(30);                    //删除容器中值为30的元素。s1.clear();                      //清除所有元素

5 set查找和统计(find、count)

//查找30是否存在,若存在,返回该键的元素的迭代器;若不存在,返回set.end();
pos = s1.find(30);//统计30的元素个数,对于set而言 统计结果 要么是0 要么是1
int num = s1.count(30); //set不允许容器中有重复的元素  

6 set和multiset区别

  • set不可以插入重复数据,而multiset不会检测数据,因此可以插入重复数据
pair::iterator,  bool>  ret = s.insert(10); //返回插入成功与否
//set插入数据的同时会返回插入结果bool值,表示插入是否成功
//若有重复元素表示插入不成功
pair::iterator, bool>  ret = s.insert(10);  //set会检测数据,返回键值对(1.插入位置,2.成功与否)
ret.first();
ret.second();
//set和multiset区别
void test01()
{set s;pair::iterator, bool>  ret = s.insert(10);if (ret.second) {cout << "第一次插入成功!" << endl;}else {cout << "第一次插入失败!" << endl;}ret = s.insert(10);if (ret.second) {cout << "第二次插入成功!" << endl;}else {cout << "第二次插入失败!" << endl;}//multiset//允许插入重复值multiset ms;ms.insert(10);ms.insert(10);for (multiset::iterator it = ms.begin(); it != ms.end(); it++) {cout << *it << " ";}cout << endl;
}int main() {test01();system("pause");return 0;
}

7 pair对组创建

//pair初始化
pair p("Tom", 20);
pair p2;  
p2 = make_pair("Jerry", 30); p.first = "xue";
p.second = 25;
p.swap(p2); //交换两个对组

7.1 用pair<int,int>建立优先队列(小根堆)

  • 比较对象是pair的第一个元素
priority_queue,vector>,greater>>pq;
  • 取元素
1.pq.top().first;
2.pq.top().second;

8 set排序 (默认从小到大,利用仿函数改变排序规则)

set s1; //默认排序从小到大 (开头是小)
//等价set >set > //排序从大到小(开头是大)
set s2; //利用仿函数MyCompare,可以改变排序规则
//对于自定义数据类型Person,set必须指定排序规则comparePerson才可以插入数据
set s;
class Person
{
public:Person(string name, int age){this->m_Name = name;this->m_Age = age;}string m_Name;int m_Age;};
class comparePerson
{
public:bool operator()(const Person& p1, const Person &p2){//按照年龄进行排序  降序return p1.m_Age > p2.m_Age;}
};void test01()
{set s;Person p1("刘备", 23);Person p2("关羽", 27);Person p3("张飞", 25);Person p4("赵云", 21);s.insert(p1);s.insert(p2);s.insert(p3);s.insert(p4);for (set::iterator it = s.begin(); it != s.end(); it++){cout << "姓名: " << it->m_Name << " 年龄: " << it->m_Age << endl;}
}
int main() {test01();system("pause");return 0;
}

二、map/ multimap(映射表)

//哈希解法
class Solution {
public:int singleNumber(vector& nums) {unordered_map hash_map;  //哈希表for(int i=0; ihash_map[nums[i]]++;  //实值累加,默认实值为0}//for(unordered_map::iterator it=m.begin();it!=m.end();it++)for(auto it : hash_map) //it不是迭代器{if(it.second == 1)return it.first;            }return 0;}
};

1 map概念(根据元素键值自动排序)

  • pair中第一个元素为key(键值),起到索引作用,第二个元素为value(实值)
  • 所有元素都会根据元素的键值自动排序

本质:

  • map/multimap属于关联式容器,底层结构是用红黑树实现。

map和multimap区别:

  • map不允许容器中有重复key值元素
  • multimap允许容器中有重复key值元素

2 map构造和赋值(默认、拷贝、=赋值)

构造:

  • 当map内元素值为int类型或常量时,默认值为0。
  • 当为String类型时,默认值不明,不显示。
//初始化
map m;   
m["def"];            //默认初始化为{def,0}   map m;      //默认构造
map m2(m);  //拷贝构造  

赋值:

m3 = m2;           //重载等号操作符
#include void printMap(map&m)
{for (map::iterator it = m.begin(); it != m.end(); it++){cout << "key = " << (*it).first << " value = " << it->second << endl;}cout << endl;
}//map容器 赋值和构造
void test01()
{//创建容器mapm; //默认构造m.insert(pair(1, 10));m.insert(pair(2, 20));m.insert(pair(3, 30));printMap(m);mapm2(m); //拷贝构造printMap(m2);mapm3;printMap(m3);
}int main() {test01();system("pause");return 0;
}

3 map大小和交换 (size、empty、swap)

m.size()         //返回容器中元素的数目
m.empty()        //判断容器是否为空
m.swap(m2);       //交换两个集合容器m.insert(pair(1, 10)); //插入数据
m.insert(make_pair(2, 20));
m.insert(map::value_type(3, 30));m[4] = 40;  //[]不建议插入用途,可以利用key访问到value

4 map插入和删除(insert、erase、clear)

//pair初始化
pair p("Tom", 20);
pair p2 = make_pair("Jerry", 30);m.insert(pair(1, 10));      //在容器中插入元素。
m.insert(make_pair(2, 20));
m.insert(map::value_type(3, 30));
m[4] = 40;         //[]不建议插入用途,可以利用key访问到valuem.erase(m.begin());             //删除pos迭代器所指的元素,返回下一个元素的迭代器。
m.erase(m.begin(), m.end());   //删除区间[beg,end)的所有元素 ,返回下一个元素的迭代器。
m.erase(3);                    //按照键值(key)3删除
m.clear();                     //清除所有元素

5 map查找和统计(find、count)

pos = m.find(3)       //查找键值key是否存在,若存在,返回该键的元素的迭代器;若不存在,返回m.end();int num = m.count(3)  //统计键值key的元素个数

6 map排序 (默认排序 按照key值 从小到大排序)

  • map容器默认排序规则为 按照key值进行 从小到大排序
  • 对于自定义数据类型,map必须要指定排序规则,同set容器
map m;     //利用仿函数MyCompare实现从大到小排序map s;  //对于自定义数据类型,map必须要指定排序规则,同set容器
class MyCompare {
public:bool operator()(int v1, int v2) {//降序return v1 > v2;}
};//map容器的排序
void test01()
{//默认从小到大排序//利用仿函数实现从大到小排序map m;m.insert(make_pair(1, 10));m.insert(make_pair(2, 20));m.insert(make_pair(3, 30));m.insert(make_pair(4, 40));m.insert(make_pair(5, 50));for (map::iterator it = m.begin(); it != m.end(); it++) {cout << "key:" << it->first << " value:" << it->second << endl;}
}
int main() {test01();system("pause");return 0;
}

相关内容

热门资讯

英伟达财报超预期,关注通信ET... 2月26日,海外算力表现较强,通信ETF开盘后持续上行,收涨2.58%。创业板人工智能ETF同步上行...
改革案例 || 市市场监督管理... 市市场监督管理局设立我省首支知识产权运营发展基金,构建“政府+资本+企业+服务机构”的知识产权运营生...
马年“开门红”!人民币汇率创3... 2026年农历马年春节刚过,中国汇市便迎来了“开门红”。 2月24日,在岸人民币对美元汇率盘中最高升...
英伟达靓丽业绩为何仍难阻股价下... 凤凰网科技讯 北京时间2月27日,据CNBC报道,英伟达的强劲财报清楚地表明,该公司仍稳坐AI芯片龙...
银联网联双增长,春节支付数据拉... 来源:华夏时报 春节期间,开封上元灯会游人如织 本报(chinatimes.net.cn)记者付乐...
原创 韩... 一部赛车电影,让80后偶像韩寒再次站到聚光灯下。 作为2026年春节档电影之一,由韩寒执导、沈腾主演...
官方辟谣“5点35背书23点2... “广河发布”微信公号 2月26日,甘肃广河县教育局发布“关于网传广河中学作息时间相关情况的通报”,具...
消费行业日均销售收入同比增长1... 本报北京2月24日电(记者 汪文正)国家税务总局增值税发票数据显示,2026年春节假期,全国消费相关...
华尔街见闻早餐FM-Radio... 华见早安之声 市场概述 英伟达财报强劲未缓解市场担忧,股价大跌近5.5%,拖累美股大盘、AI概念...
榆煤基金再次入选陕西基金管理人... 根据中国证券投资基金业协会数据,陕西省证券投资基金业协会全面系统梳理了省内私募投资基金管理人发展全景...
三部门发布“十五五”期间能源资... 财政部 海关总署 税务总局关于“十五五”期间能源资源勘探开发利用进口税收优惠政策的通知财关税〔202...
CoreWeave电话会:CE... AI基础设施供应商CoreWeave一季度指引逊预期拖累股价,盘后重挫逾9%,全年展望仍具支撑。 2...
五连涨!人民币持续升值,受益股... 多家公司就人民币升值对业务的影响进行回应。 春节过后,人民币兑美元汇率迎来连续升值。 2月26日,美...
ETF规模速报 | 恒生科技E... 昨日市场探底回升,三大指数涨跌不一,创业板指盘中一度跌超1%。板块来看,PCB、CPO、液冷服务器、...
兆威机电今起招股,引入高瓴、未... 来源:独角兽早知道 兆威机电(02692.HK)发布公告,公司拟全球发售2674.83万股H股,中...
一线城市打响新年楼市升温“第一... 马年春节复工首周,一线城市率先发力,打响新年楼市复苏的“第一枪”。2月25日,广州天河马场地块的出让...
人民币汇率持续走强(锐财经) 近日,在浙江义乌中国进口商品城一家主营西班牙进口商品的店铺内,顾客选购西班牙火腿和红酒。 新华社记者...
2月27日美股成交额前20:英... 来源:环球市场播报 周四美股成交额第1名英伟达收跌5.46%,成交664.55亿美元。由于英伟达的大...
原创 请... 黄金价格在2026年2月26日站上5200美元/盎司,这是继1月底突破5500美元历史高位后的又一次...