【STL——set与multiset容器】

引入

set和multiset是C++ STL中的两种关联容器,基于红黑树(平衡二叉树)实现,用于存储一组有序的元素。两者的主要区别在于元素的唯一性:

set中的元素必须唯一 ,不允许重复。
multiset允许 存储重复的元素。

set

按惯例先添头文件

#include

构造与赋值
cpp 复制代码
	set<int> st;       //默认构造函数

	set<int> st1(st);  //拷贝构造函数
	set<int> st2 = st; //重载等号操作符(也属拷贝构造函数)

	set<int> st3;
	st3 = st2;    //赋值构造函数
插入与删除
cpp 复制代码
void test() {
	set<int> s1;     
	s1.insert(10);
	s1.insert(90);
	s1.insert(30);
	s1.insert(20);
	printSet(s1); //默认顺序输出:10、20、30、90
	s1.erase(s1.begin()); //删除s1的第一个元素(10)
	printSet(s1); //输出:20、30、90
	s1.erase(30); //删除30
	printSet(s1); //输出:20、90
	s1.clear();   //清空
	printSet(s1); //无输出
}
大小与交换
cpp 复制代码
void test() {  
	set<int> s1 = { 10,90,30 }; //简便写法
	printSet(s1); //默认顺序输出:10、30、90
	cout <<"s1现在的大小为:" <<s1.size() << endl; //size=3
	s1.erase(s1.begin()); //删除s1的第一个元素(10)
	printSet(s1); //输出:30、90
	cout << "s1现在的大小为:" << s1.size() << endl; //size=2
	set<int> s2 = { 20,39,48,10 };
	s2.swap(s1);
	printSet(s1); //输出:10、20、39、48
	s1.clear();   //清空
	cout << "s1现在的大小为:" << s1.size() << endl; //size=0
	if (s1.empty()) {
		cout << "s1为空" << endl;
	}
	else {
		cout << "s1不为空" << endl;
	}
	printSet(s1); //无输出
}
查找与统计
cpp 复制代码
void test() {  
	set<int> s1 = { 10,90,30 }; //简便写法
	//set<int>::iterator i=s1.find(90);
	auto i=s1.find(90); //两种写法都可以
	if (i != s1.end()) {
		cout << *i << endl;
	}
	else {
		cout << "未找到该元素" << endl;
	}
	cout <<s1.count(30)<< endl; //30仅有1个,输出1
	s1.insert(30);
	s1.insert(30);
	cout << s1.count(30) << endl; //set不允许有重复元素出现,仍输出1
}

Multiset

Multiset允许存储相同元素,但在使用find()函数返回时返回的是参数匹配的第一个元素的迭代器,即存在多个相同元素时返回第一个。如果没有符合的参数则结束迭代器。

此外,在insert()时还能插入一段数据。

cpp 复制代码
void test() {  
	multiset<int> ms;
	ms.insert(20);
	ms.insert(90);
	ms.insert(10);
	ms.insert(20);
	ms.insert(70);
	printSet(ms); //输出:10、20、20、70、90
	int it = 0;
	for (auto i = ms.begin(); i != ms.find(70); i++, it++) {}
		cout << "发现20的位置在" << it << endl; //输出:3
	
	multiset<int> ms1;
	auto i = ms.begin()++;
	i++;
	ms1.insert(ms.begin(), i); //这里和上篇相同,不能直接给begin做加减
	printSet(ms1); 
}
相关推荐
计算机安禾5 分钟前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio
unicrom_深圳市由你创科技9 分钟前
做虚拟示波器这种实时波形显示的上位机,用什么语言?
c++·python·c#
无限进步_15 分钟前
【C++】电话号码的字母组合:从有限处理到通用解法
开发语言·c++·ide·windows·git·github·visual studio
JJay.29 分钟前
Android Kotlin 协程使用指南
android·开发语言·kotlin
csbysj202035 分钟前
jQuery 捕获详解
开发语言
C++ 老炮儿的技术栈44 分钟前
GCC编译时无法向/tmp 目录写入临时汇编文件,因为设备空间不足,解决
linux·运维·开发语言·汇编·c++·git·qt
橘颂TA1 小时前
【笔试】算法的暴力美学——牛客 NC213140 :除2!
c++·算法·结构与算法
三道渊1 小时前
进程通信与网络协议
开发语言·数据库·php
白露与泡影1 小时前
Java面试题库及答案解析(2026版)
java·开发语言·面试
wsoz1 小时前
Leetcode普通数组-day5、6
c++·算法·leetcode·数组