集合(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的更多相关文章

  1. 【stl学习笔记】set、multiset

    set和multiset会根据特定的排序准则,自动将元素排序.两者不同处在于multiset允许元素重复而set不允许 在使用set或multiset之前,必须先加入头文件<set> se ...

  2. C++STL标准库学习笔记(三)multiset

    C++STL标准库学习笔记(三)multiset STL中的平衡二叉树数据结构 前言: 在这个笔记中,我把大多数代码都加了注释,我的一些想法和注解用蓝色字体标记了出来,重点和需要关注的地方用红色字体标 ...

  3. Effective STL 学习笔记: Item 22 ~ 24

    Effective STL 学习笔记: Item 22 ~ 24 */--> div.org-src-container { font-size: 85%; font-family: monos ...

  4. Effective STL 学习笔记 Item 21:Comparison Function 相关

    Effective STL 学习笔记 Item 21:Comparison Function 相关 */--> div.org-src-container { font-size: 85%; f ...

  5. Effective STL 学习笔记 39 ~ 41

    Effective STL 学习笔记 39 ~ 41 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  6. 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 ...

  7. Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据

    Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据 */--> div.org-src-container { font-size: 85%; font-fam ...

  8. Effective STL 学习笔记 32 ~ 33

    Effective STL 学习笔记 32 ~ 33 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  9. Effective STL 学习笔记 31:排序算法

    Effective STL 学习笔记 31:排序算法 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...

  10. Effective STL 学习笔记 Item 30: 保证目标区间足够大

    Effective STL 学习笔记 Item 30: 保证目标区间足够大 */--> div.org-src-container { font-size: 85%; font-family: ...

随机推荐

  1. 数据类型 -- uint32_t 类型

    整型的每一种都有无符号(unsigned)和有符号(signed)两种类型(float和double总是带符号的),在默认情况下声明的整型变量都是有符号的类型(char有点特别),如果需声明无符号类型 ...

  2. MVC+Nhibernate+jquery+easyui递归实现多级菜单

    1.新建访问的控制器动作返回视图,在视图中使用easyui的treegrid插件来得到后台得到的json数据显示多级菜单 public ActionResult Menu() { return Vie ...

  3. win10安装mac系统

    https://baijiahao.baidu.com/s?id=1587241720383991895&wfr=spider&for=pc https://mp.weixin.qq. ...

  4. Linux 文件的压缩与解压

    1.  tar结尾压缩命令 [root@test ~]# tar -cvf grub.tar /boot/grub/ 查看压缩包文件 [root@test ~]# tar -vtf grub.tar ...

  5. python_13_break

    for i in range(5): print('-----------',i) for j in range(5): print(j) if j>2: break####结束当前循环

  6. highcharts与ajax的应用

    整理一份完整的例子,以供参考: <1>页面chart.html: <span style="font-size:14px;"><!DOCTYPE HT ...

  7. Vimim是VI中最好的输入法

    Vimim是VI中最好的输入法 由于在VI中,normal和insert模式的存在,如果在insert模式下正在输入中文,在通过ESC键返回到normal模式后,系统的中文输入法会与VI的命令相冲突, ...

  8. vue学习之路 - 3.基本操作(中)

    基本操作(中) 本章节主要介绍:vue的条件渲染.列表渲染,计算属性和侦听器 条件渲染和列表渲染 条件渲染主要使用到了 v-if 指令,列表渲染主要使用了 v-for 指令. 下面介绍 v-if .  ...

  9. 牛客小白月赛5 D 阶乘(factorial) 【前缀】

    链接:https://www.nowcoder.com/acm/contest/135/D 题目描述 输入描述: 输入数据共一行,一个正整数n,意义如“问题描述”. 输出描述: 输出一行描述答案: 一 ...

  10. 学习 KMP 算法

    KMP 算法是用来处理字符串匹配问题的.也就是给你两个字符串,你需要回答:B 串是否是 A 串的子串(或 B 串在 A 串中出现的位置).比如,字符串 A = “ i am student ”, 字符 ...