set/multiset_01
按序排列
不能指定插入位置
红黑树变体
不可以直接存取元素(即 无[?]/at(?)操作)
不可以直接修改元素值(用 先删除后添加的方式,达到相同效果)
A、头尾 添加/移除
B、随机存取
C、数据存取
1、构造函数
1.1、默认构造函数 ==> 无参构造函数
1.2、必定需要 复制构造函数 :set<T> setT(const set& st);
1.3、set<T> setT(iteratorBegin, iteratorEnd); // 迭代器区间[iteratorBegin, iteratorEnd)拷贝给setT
注意: 这里可以传数组指针,数组指针在特定情况下可以当做迭代器使用
1.4、无 // n个elemValue复制给lstT
2、赋值
2.1、重载"="操作符
set& = const set& vec;
2.2、无 // [beg, end)区间拷贝给
2.3、无 // n个elemValue拷贝给
3、迭代器操作
3.1、const_iterator set<T>::begin(); // 第1个
3.2、const_iterator set<T>::end(); // 最后1个
3.3、const_reverse_iterator set<T>::rbegin(); // 倒数第1个
3.4、const_reverse_iterator set<T>::rend(); // 倒数最后1个
4、插入
注意: 拷贝插入(ZC: 也就是类实例的话,类必须提供复制构造函数)
std::pair<set<T>::iterator, bool> pair = set::insert(elemValue); // 返回pair<指向新元素的iterator, 插入是否成功>,拷贝插入
5、删除
void set::clear();
iterator set::erase(const_iterator beg, const_iterator end); // [beg, end)区间,返回下一个元素的位置(迭代器)
iterator set::erase(const_iterator pos); // 返回下一个元素的位置(迭代器)
size_type set::erase(elemValue); // 删除 容器中 值为 elemValue的元素
6、交换
void set<T>::swap(set<T>&);
7、大小
size_type set<T>::size();
bool set<T>::empty();
8、查找
iterator set::find(key_value elem); // 返回指向elem的迭代器
size_type set::count(key_value elem); // 返回容器中值为elem的元素个数
iterator set::lower_bound(key_value elem); // 返回第一个>=elem元素的迭代器
iterator set::upper_bound(key_value elem); // 返回第一个>elem元素的迭代器
std::pair<set<T>::iterator, set<T>::iterator> pair01 = setT.equal_range(key_value elem); // 返回容器中与elem相等的上下限的两个迭代器。上限是闭区间,下限是开区间。如[beg, end)
9、排序
9.1、默认排序函数
less<T>
greater<T>
set/multiset_01的更多相关文章
随机推荐
- spark shuffle原理
1.spark中窄依赖的时候不需要shuffle,只有宽依赖的时候需要shuffle,mapreduce中map到reduce必须经过shuffle 2.spark中的shuffle fetch的时候 ...
- 4.keras实现-->生成式深度学习之用变分自编码器VAE生成图像(mnist数据集和名人头像数据集)
变分自编码器(VAE,variatinal autoencoder) VS 生成式对抗网络(GAN,generative adversarial network) 两者不仅适用于图像,还可以 ...
- iOS开发--图片轮播
直接上代码了,比较简单.演示下载地址:Demo // // UYViewController.m // 图片轮播器 // // Created by jiangys on 15/5/23. // Co ...
- iOS下拉刷新和上拉刷新
在iOS开发中,我们经常要用到下拉刷新和上拉刷新来加载新的数据,当前这也适合分页.iOS原生就带有该方法,下面就iOS自带的下拉刷新方法来简单操作. 上拉刷新 1.在TableView里,一打开软件, ...
- String源码详解
一.基本概念. 1.继承实现关系.因为被final修饰,因此是不可继承的String类,避免被他人继承后修改.实现了三个接口.可序列.可比较,有序.几个String兄弟类 2.本质就是字符数组,同时, ...
- 浅谈EM算法的两个理解角度
http://blog.csdn.net/xmu_jupiter/article/details/50936177 最近在写毕业论文,由于EM算法在我的研究方向中经常用到,所以把相关的资料又拿出来看了 ...
- Asp.net Mvc5的认识
前言:以前总说自己玩mvc,但是对mvc的认识还是不够透彻,也没有好好看微软自带的mvc项目中的精妙,最近闲了下来,好好看了看. 通过上图,我们可以清晰地了解到MVC 5应用程序的项目结构,接下来我们 ...
- tablix“Tablix1”有一个具有内部成员的详细信息成员
做报表的时候出现了这个错误: 错误 1 tablix“Tablix1”有一个具有内部成员的详细信息成员.详细信息成员只能包含静态内部成员. 解决方案: 原因:在一个报表里面插入两个表格的时候:会出现 ...
- 小试---EF5.0简介
简介 实体框架Entity Framework 是 ADO.NET 中的一组支持开发面向数据的软件应用程序的技术.是微软的一个ORM框架.简单的说就是把关系型数据库映射成面向对象模型. 一篇更加详细的 ...
- ajax 拦截器设置请求头
使用vue-resource时,往headers里添加token后,post方法会自动变成options? Vue.http.interceptors.push(function(request, n ...