STL学习笔记4--set and multiset
集合(Set)是一种包含已排序对象的关联容器。多元集合(MultiSets)和集合(Sets)相像,只不过支持重复对象,其用法与set基本相同。
用法介绍
1.insert()函数
首先把头文件set包含进去 #include "set"
set <int> test1;
set <int>::iterator it1;
multiset <int> test2;
multiset <int>::iterator it2;
//////////////////////////////////////////////////////////////////////////
//输入
it1 = test1.begin();
it2 = test2.begin();
for (int j=;j<=;j++)
{
test1.insert(it1,j);//直接在最后面插入数据
test2.insert(it2,j*);
}
2、输出的话,可以直接取地址
cout<<"Elements:";
for ( it1=test1.begin() ; it1 != test1.end(); it1++ )
cout << " " << *it1;//直接取地址
cout<<endl;
3、find() and erase()查找元素和删除元素,需要注意的是当元素不存在是find会出错
//查找和删除,当元素不存在是find会出错
it1 = test1.find();//查找某元素位置
test1.erase(it1);//删除元素
test1.erase(test1.find());//结合起来写 for ( it1=test1.begin() ; it1 != test1.end(); it1++ )
cout << " " << *it1;
cout<<endl;
4、count() 函数,元素计数,set中可用于判断元素是否存在
//count,计数,可用来判断元素是否存在,因为set中元素不允许重复
test2.insert();
cout<<"multiset的元素可以重复:"<<test2.count()<<endl;
for (int i=;i<; i++)
{
cout << i;
if (test1.count(i)>)//只能有一个元素
cout << " is an element of test1.\n";
else
cout << " is not an element of test1.\n";
}
5、equal_range()函数 返回第一个>=关键字的迭代器和>关键字的迭代器 ,也就是你要查找的元素的指针和它下一个元素的指针。
//equal_range() 返回第一个>=关键字的迭代器和>关键字的迭代器
pair<set<int>::iterator,set<int>::iterator> ret;//注意用法 pair
ret = test1.equal_range();//查找元素5的迭代器和它下一个迭代器,如果不存在,则这两个迭代器都指向是下一个元素
cout<<"lower bound points to:"<<*ret.first<<endl;
cout<<"upper bound points to:"<<*ret.second<<endl;//不能越界
6、 lower_bound() 返回指向大于(或等于)某值的第一个元素的迭代器
upper_bound() 返回大于某个值元素的迭代器
这两个函数结合在一起,可用来修改或者删除某一个范围内的元素
set <int>::iterator itlower,itupper;
itlower = test1.lower_bound();//指向大于等于5的迭代器
itupper = test1.upper_bound();//指向大于9的迭代器
test1.erase(itlower,itupper);//erase data from 5 to 10
cout<<"Element:";
for ( it1=test1.begin() ; it1 != test1.end(); it1++ )
cout << " " << *it1;
cout<<endl;
7 swap 交换两个集合变量 中的所有元素
//swap 交换两个集合变量 中的所有元素
set <int> test3;
set <int>::iterator it3;
it3 = test3.begin();
for (int j=;j<=;j++)
{
test3.insert(it3,j*);//直接在最后面插入数据 }
swap(test1,test3);
8、empty(),clear() 清空数据
test1.clear();
if (test1.empty())
{
cout<<"set is null"<<endl;
}
set集合函数很简单,就这么多常用功能。更复杂的是在使用很灵活
STL学习笔记4--set and multiset的更多相关文章
- 【stl学习笔记】set、multiset
set和multiset会根据特定的排序准则,自动将元素排序.两者不同处在于multiset允许元素重复而set不允许 在使用set或multiset之前,必须先加入头文件<set> se ...
- C++STL标准库学习笔记(三)multiset
C++STL标准库学习笔记(三)multiset STL中的平衡二叉树数据结构 前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标 ...
- Effective STL 学习笔记: Item 22 ~ 24
Effective STL 学习笔记: Item 22 ~ 24 */--> div.org-src-container { font-size: 85%; font-family: monos ...
- Effective STL 学习笔记 Item 21:Comparison Function 相关
Effective STL 学习笔记 Item 21:Comparison Function 相关 */--> div.org-src-container { font-size: 85%; f ...
- Effective STL 学习笔记 39 ~ 41
Effective STL 学习笔记 39 ~ 41 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- Effective STL 学习笔记 Item 38 : Design functor classes for pass-by-value
Effective STL 学习笔记 Item 38 : Design functor classes for pass-by-value */--> div.org-src-container ...
- Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据
Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据 */--> div.org-src-container { font-size: 85%; font-fam ...
- Effective STL 学习笔记 32 ~ 33
Effective STL 学习笔记 32 ~ 33 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- Effective STL 学习笔记 31:排序算法
Effective STL 学习笔记 31:排序算法 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- Effective STL 学习笔记 Item 30: 保证目标区间足够大
Effective STL 学习笔记 Item 30: 保证目标区间足够大 */--> div.org-src-container { font-size: 85%; font-family: ...
随机推荐
- 【转】如何在Git中撤销一切
翻译:李伟 审校:张帆译自:Github 任何一个版本控制系统中,最有用的特性之一莫过于 “撤销(undo)”操作.在Git中,“撤销”有很多种含义. 当你完成了一次新的提交(commit),Git会 ...
- 常用宏OC
#ifndef MacroDefinition_h #define MacroDefinition_h //-------------------获取设备大小--------------------- ...
- pta编程题19 Saving James Bond 2
其它pta数据结构编程题请参见:pta 题目 和简单版本不同的是,简单版本只需判断能否到达岸边,而这个版本要求求出最少跳数的路径. 简单版本用dfs实现,而这道题用BFS实现. 注意: 岛半径为7.5 ...
- System.FormatException: GUID 应包含带 4 个短划线的 32 位数(xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx)。解决办法
查一下数据库的UID数据是否格式正确,如: 错误格式1: {E056BB36-D824-4106-A9C3-D8D8B9ADC1C 错误格式2: E056BB36-D824-4106-A9C3-D8D ...
- Nginx源码安装及调优配置(转)
导读 由于Nginx本身的一些优点,轻量,开源,易用,越来越多的公司使用nginx作为自己公司的web应用服务器,本文详细介绍nginx源码安装的同时并对nginx进行优化配置. Nginx编译前 ...
- object-detection-crowdai数据处理
import os file=os.listdir('/home/xingyuzhou/object-detection-crowdai') file.sort(key= lambda x:int(x ...
- React后台管理系统- rc-pagination分页组件封装
1.用户列表页面使用的rc-pagination分页组件 Github地址: https://github.com/react-component/pagination 2.安装 cnpm insta ...
- java算法面试题:编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串,但要保证汉字不被截取半个, 如“我ABC”,4,应该截取“我AB”,输入“我ABC汉DEF”,6,应该输出“我ABC”,而不是“我ABC+汉的半个”。
package com.swift; import java.util.Scanner; public class Hanzi_jiequ { public static void main(Stri ...
- es6展开运算符
数组的展开合并 现在有两个数组[1, 2, 3, 4]和[5, 6, 7],想要将两个函数拼接成一个新的函数. //es5的写法 let arr1 = [1, 2, 3, 4]; let arr2 = ...
- SAP后台JOB的Submit & EVENT JOB
SM35执行一个后台作业后,想及时停止, 运行SM37后,点击ctr + F1停止活动的作业,系统根本就没反应. 解决方法: 第一步:SM50, 找到,Ty.列为BGD的(Background),然后 ...