24.map set(下)

valuetype就是T,

找logN

删除成功了就返回1,没删除成功就返回0

类似以下节点删掉 pos失效

一种是有做孩子或者右孩子,删除后,野指针问题,另一种是替代法,也认为是失效,意义变了

第二个更好

支持两个树swap,两个树swap,swap根节点就行,

返回这个值在里面的个数

cpp 复制代码
int main()
{
	std::set<int> myset;
	for (int i = 1; i < 10; i++)
		myset.insert(i * 10); // 10 20 30 40 50 60 70 80 90
	for (auto e : myset)
	{
		cout << e << " ";
	}
	cout << endl;

	// [30, 50]值
	// [25, 55]值
	 
	//// 返回 >= 30
	//auto itlow = myset.lower_bound(30);
	//// 返回 > 50
	//auto itup = myset.upper_bound(50);

	// 返回 >= 25
	auto itlow = myset.lower_bound(25);
	// 返回 > 55
	auto itup = myset.upper_bound(55);

	// 删除这段区间的值
	myset.erase(itlow, itup);
	for (auto e : myset)
	{
		cout << e << " ";
	}
	cout << endl;
}

删除是左闭右开

等于的值好找,大于的往上回,遍历就不划算了。

multiset不需要单独包头文件接口一样

差异:删除查找,好多个4找哪个,找中序第一个,左子树有三就是中序第一个

3比1大,往右找,找到这个3再继续往下找,说不定还有三

找到第一个,返回迭代器++就按照中序往后找

这个是删除所有4

这里更简单

查找中序第一个删除有多个通通干掉

交集要去重,如果放到set会天然去重,会排序

差集怎么办

看看3 2 0 -4在不在set内,不在就插入,在就带环就是环的入口点

这个可以改

之前搜索树分散放的。现在把key value放到结构体里面,结构体有两个成员fist 就是key second就是value,多封了一层,这是pair

pair没重载流茶入流提取所以变异不通过

存的结构可用->,

map不允许荣誉,如果key相等 value不相等,不会更新value,key相等就结束了

本质是两个const char*给initial list推出initial list是个pair,隐式类型转换成pair的stirng stirng.

一个是隐式类型转换一个是initiallizer list

相关推荐
c++之路20 分钟前
C++信号处理
开发语言·c++·信号处理
_深海凉_2 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
故事还在继续吗2 小时前
C++20关键特性
开发语言·c++·c++20
青少儿编程课堂3 小时前
2026青少儿信息素养大赛备赛指南!Python/Scratch/C++备考要点
开发语言·c++·python
旖-旎3 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰3 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx3 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer4 小时前
【无标题】
开发语言·c++·算法
John_ToDebug4 小时前
WebHostView 与 TabStrip 交互机制深度解析
c++·chrome·windows
AGV算法笔记4 小时前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉