C++ set和map

set

set的底层就是一个二叉搜索树,具有去重和排序的功能

cpp 复制代码
#include<iostream>
#include<set>
using namespace std;

int main()
{
	set<int> s;
	s.insert(1);
	s.insert(5);
	s.insert(4);
	s.insert(6);
	s.insert(3);
	s.insert(5);
	s.insert(6);

	set<int> s1(s.begin(), s.end());
	for (auto e : s) cout << e << " ";
	cout << endl;
	for (auto e : s1)cout << e << " ";
	return 0;
}

输出结果

当按照迭代器去遍历set的时候,发现它是按照升序的顺序打印的,由此可以说明,begin()函数返回的是set中序的的第一个元素,那么end()成员函数返回的就是中序序列的最后一个元素,

count函数

该函数返回的是元素是否在set当中,有就返回1,没有就返回0

cpp 复制代码
void test02()
{
	set<int> s;
	s.insert(1);
	s.insert(5);
	s.insert(4);
	s.insert(6);
	s.insert(3);
	s.insert(5);
	s.insert(6);

	cout << s.count(5) << endl;
}

运行结果

lower_bound和uper_bound函数

lower_bound(x):返回的大于等于x值的第一个元素的迭代器

uper_bound(x):返回的是大于x值的第一个元素的迭代器

cpp 复制代码
void test02()
{
	set<int> s;
	s.insert(1);
	s.insert(5);
	s.insert(4);
	s.insert(6);
	s.insert(3);
	s.insert(5);
	s.insert(6);
	s.insert(2);

	set<int>::iterator it = s.lower_bound(2);    //大于等于2的第一个元素的迭代器
	cout << *it << endl;

	set<int>::iterator it1 = s.upper_bound(2);  //大于2的第一个元素的迭代器
	cout << *it1 << endl;

}

运行结果:

要是找不到的话,再去访问该元素,程序会是崩溃的,所以,需要确保参数的值要小于set里面元素的最大值

multiset容器

multiset容器底层也是二叉搜索树,与set不同的是,multiset中支持多个相同的值,也就是说,里面可以存在多个相同的值,至于插入一个一个存在的值,可以插在这个值的左边,也可以插在这个值的右边,但是,值得注意的是,find一个值的时候,且这个值不止一个,那返回的是中序遍历的第一个值

cpp 复制代码
void test04()
{
	multiset<int> s;
	s.insert(2);
	s.insert(4);
	s.insert(1);
	s.insert(4);
	s.insert(6);

	multiset<int>::iterator it = s.find(4);
	while (it != s.end())
	{
		cout << *it <<" ";
		it++;
	}
}

运行结果:

关于set,我们就介绍这么多,其他的接口,看接口也能看得明白

map

map底层也是二叉搜索树,属于二叉搜索树当中的<k,val>模型,定义的时候如下

cpp 复制代码
void test05()
{
	map<string, string> m;                             //map插入的几种方式
	m.insert({ "insert","插入" });
	m.insert(pair<string, string>("left", "左边"));
	m.insert(make_pair("right", "左边"));
	pair<string, string> s = { "string", "字符串" };
	m.insert(s);

	for (auto e : m) cout << e.first << " " << e.second << endl;     //遍历的第一种方式
	cout << "/////////////////////////////////////////////////////////////////" << endl;
	map<string, string>::iterator it = m.begin();                    //遍历的第二种方式
	while (it != m.end())
	{
		cout << it->first << " " << it->second << endl;
		it++;
	}
}

运行结果:

operator[]函数

cpp 复制代码
void test06()
{
	map<int, string> m = { {1,"hello"},{2,"world"},{3,"fuck"},{4,"you"} };
	cout << m[1] << endl;

}

运行结果

由此课件,map[第一次参数的值]=第二个参数的值

值得注意的是,当map[k]存在的时候,给其复制就是修改对应的值,如果没有,就是新插入一个值

cpp 复制代码
void test06()
{
	map<int, string> m = { {1,"hello"},{2,"world"},{3,"fuck"},{4,"you"} };
	m[5] = "beautiful";
	m[1] = "love";
	for (auto e : m) cout << e.first << ":" << e.second <<endl;

}

运行结果:

统计次数

cpp 复制代码
void test07()
{
		string arr[] = { "苹果", "西瓜", "苹果", "西瓜", "苹果", "苹果", "西瓜", "苹果", "香蕉", "苹果", "香蕉" };
		map<string, int> countTree;
		for (const auto& str : arr)
		{
			// 先查找水果在不在搜索树中
			// 1、不在,说明水果第一次出现,则插入<水果, 1>
			// 2、在,则查找到的节点中水果对应的次数++
			//BSTreeNode<string, int>* ret = countTree.Find(str);
			auto ret = countTree.find(str);
			if (ret == countTree.end())
			{
				countTree.insert({ str, 1 });
			}
			else
			{
				ret->second++;
			}
		}

		for (const auto& e : countTree)
		{
			cout << e.first << ":" << e.second << endl;
		}
		cout << endl;

}

运行结果:

注意,有multiset容器,那么就一定存在multimap容器,容器的使用和multiset一样,这里便不再多赘述

相关推荐
小陈phd2 小时前
langGraph从入门到精通(三)——基于LangGraph的智能问答系统开发:Python单代理架构实战
开发语言·python·架构
学嵌入式的小杨同学2 小时前
顺序表(SqList)完整解析与实现(数据结构专栏版)
c++·算法·unity·游戏引擎·代理模式
格林威2 小时前
多光源条件下图像一致性校正:消除阴影与高光干扰的 6 个核心策略,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·计算机视觉·分类·视觉检测
iAkuya2 小时前
(leetcode)力扣100 40二叉树的直径(迭代递归)
java·算法·leetcode
电子_咸鱼2 小时前
Linux IPC 实战:管道与共享内存的使用场景 + 底层原理全剖析
linux·运维·服务器·开发语言·网络·vscode·qt
smile_5me2 小时前
RK3588 csm400b调试记录
c语言·开发语言
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——leetCode 103 题:二叉树的锯齿形层序遍历
算法·leetcode·结构与算法
2501_901147832 小时前
高性能计算笔记:灯泡开关问题的数学优化与常数级解法
笔记·算法·求职招聘
C_心欲无痕2 小时前
JavaScript 常见算法与手写函数实现
开发语言·javascript·算法