vector:相当于一个不定长数组。

vector的扩充机制是按照现在容量的一倍进行增长,每次增长是重新申请一块更大的心内存,并把现在容器中的元素逐个复制过去,然后销毁旧的内攒
1.头文件:
#include<vector>
2.定义vector对象:
vector<int> a; //创建一个空的容器
vector<int> b(10,1);//创建一个初始10个元素,每个元素为1的数组
vector<int> c(b.begin()+5,b.end());//选取从b的第五个元素开始到结束的元素创建一个新的容器
vector<int> d(b);//创建一个和b一样的容器
vector<int> e(10);//创建一个有10个元素的容器
3.基本操作函数
vector<int>::iterator it=b.begin();//创建一个vector<int>的迭代器
c.begin();-------------------返回容器c的起始位置的迭代器
c.end():---------------------返回容器c的最后位置的迭代器
c.push_back(t);--------------向数组最后插入元素
c.pop_back(t);---------------删除数组最后一个元素
b.at(3);---------------------返回编号为3的数据
b.front();-------------------返回数组的第一个元素的值
b.back();--------------------返回数组的最后一个元素的值
b.insert(it+i,t)-------------在第i+1个元素前插入一个元素
b.assign(a.begin(),a.end())--将容器a的值赋值给容器b
b.erase(b.begin()+5);--------删除第6个元素
b.erase(it+1,it+4);----------删除第2个元素到第五个元素
b.size();--------------------返回容器大小
b.swap(d);-------------------将b和d交换数据
b.clear();-------------------清空当前的vector

set:就是数学上的集合——每个元素最多出现一次

1.头文件
#include <set>
2.定义set对象:
set<int> a;//创建一个空的set容器
set<int> b(a.begin(),a.end());//创建一个从a.begin()到a.end()的容器,可以定义迭代器进行移动位置
set<int> c(a);//创建一个和a一样的容器
3.基本操作函数:b.assign(a.begin(),a.end())--将容器a的值赋值给容器b
b.erase(b.begin()+5);--------删除第6个元素
a.begin();-------------------返回开始的迭代器
a.end();---------------------返回最后的迭代器
a.insert(t);-----------------将元素t插入容器
a.count(t);------------------判断a里有没有值为t的元素若存在返回1否则返回0
a.empty();-------------------判断容器是否为空,如果为空返回1否则返回0
a.size();--------------------返回容器内元素的个数
a.erase(a.begin());----------删除首元素
a.erase(a.begin(),a.end());--删除区间内元素
a.erase(3);------------------删除值为3的元素
a.find(3);-------------------返回值为3的迭代器
a.swap(b);-------------------交换两个容器的值
a.clear();-------------------清空当前set

map:就是从键到值得映射,重载了[]运算符

map像数组的“高级版”,例如:map<string,int> mouth_name; 可以用这样的方式复制mouth_name["July"]=7(如果没有July下标的实例会自动插入
map和set很相似,map允许重复元素,并且map比set多一个键值
1.头文件
#include <map>
2.定义map对象:
max<int,string> a;
3.常用函数
a.begin();--------------------------------------返回开始的迭代器
a.end();----------------------------------------返回最后的迭代器
a.insert(pair<int,string>(123,"abcde"));--------插入下标为123值为abcde的元素
a.begin()->first;-------------------------------定义max<int,string> a来说,表示map对象第一个元素的int型数据
a.begin()->second;------------------------------定义max<int,string> a来说,表示map对象第二个元素的string型数据
a.find(3)---------------------------------------返回下标为3的元素的迭代器,如果没有返回最后一个元素的迭代器
a.count(2)--------------------------------------判断a里有没有下标为2的元素若存在返回1否则返回0
a.erase(2)--------------------------------------删除键为2的元素
a.erase(a.begin());-----------------------------删除第1个元素
a.erase(a.begin(),a.end());---------------------删除区间内元素
a.empty();--------------------------------------判断容器是否为空,如果为空返回1否则返回0
a.size();---------------------------------------返回容器内元素个数
a.swap(b);--------------------------------------交换两个容器的值
a.clear();--------------------------------------清空当前map

stack:栈

1.头文件
#include<stack>
2.定义stack对象:
stack<int> a;
3.基本操作函数:
int t;
a.push(t);----------将t的值入栈,无返回值
a.pop();------------出栈无返回值,无返回值
a.empty();----------判断栈是否为空,如果为空返回1否则返回0
a.top();------------返回栈顶元素
a.size();-----------返回栈的元素数目

queue:队列

1.头文件
#include<queue>
2.定义queue对象:
queue<int> a;
3.基本操作函数:
int t;
a.push(t);----------将t入队,无返回值
a.pop();------------删除第一个元素
a.empty();----------判断队列是否为空,如果为空返回1否则返回0
a.front();----------返回队列第一个元素
a.back();-----------返回队列最后一个元素
a.size();-----------返回队列长度

list:双向链表

1.头文件
#include<list>
2.定义list对象
list<int> L0; // 空链表
list<int> L1(9); // 建一个含个默认值是的元素的链表
list<int> L2(5,1); // 建一个含5个元素的链表,值都是1
list<int> L3(L2); // 建一个L2的copy链表
list<int> L4(L0.begin(), L0.end());//建一个含L0一个区域的元素
3.基本操作函数:
L1.assign(4,3);----------------------分配4个元素,值为3
L1.assign(L2.begin(),L2.end());------分配区间的分配值
L1.begin();--------------------------返回第一个元素的迭代器
L1.end();----------------------------返回最后一个元素的下一个元素的迭代器
L1.push_back(4);---------------------插入一个元素到链表尾
L1.push_front(4);--------------------插入一个元素到链表头
L1.pop_back();-----------------------删除最后一个元素
L1.pop_front();----------------------删除第一个元素
L1.erase(L1.begin());----------------删除迭代器指向的元素
L1.erase(L1.begin(),L1.end());-------删除区间元素
L1.remove(3);------------------------删除链表中值为3的全部元素
L1.size();---------------------------返回链表的值
L1.reverse();------------------------反转链表
L1.sort();---------------------------将链表的值升序排列
L1.sort(greater<int>());-------------降序排列
L1.swap(L2);-------------------------L1和L2的值互换
L1.unique();-------------------------删除相邻重复元素
L1.clear();--------------------------清空链表

STL常用的容器的更多相关文章

  1. STL常用序列容器

    这里简要的记述一下STL常用容器的实现原理,要点等内容. vector vector是比较常用的stl容器,用法与数组是非类似,其内部实现是连续空间分配,与数组的不同之处在于可弹性增加空间,而arra ...

  2. STL - 常用关联容器代码 - set & multiset

    代码如下: /* 5. set & multiset */ set<string> cities{ "Braunschweig", "Hanover& ...

  3. STL - 常用顺序容器代码

    不多说,看代码 #include <iostream> #include <vector> #include <deque> #include <list&g ...

  4. STL常用容器使用方法

    在程序头部使用#include<stack>来引入STL的stack容器,然后使用stack<int> s语句来声明一个管理整型数据的容器s.stack常用成员函数:push( ...

  5. 【Example】C++ STL 常用容器概述

    前排提醒: 由于 Microsoft Docs 全是机翻.所以本文表格是我人脑补翻+审校. 如果有纰漏.模糊及时评论反馈. 序列式容器 序列容器是指在逻辑上以线性排列方式存储给定类型元素的容器. 这些 ...

  6. c++ STL 常用容器元素类型相关限制 指针 引用

    c++ 的 STL 中主要有 vector , list, map, set  , multimap,multiset 这些容器完全支持使用内置类型和指针(指针注意内存泄露问题). 就是说乱用智能指针 ...

  7. STL——序列式容器

    一.容器概述与分类 1. STL容器即是将运用最广的一些数据结构实现出来.常用的数据结构有array, list, tree, stack, queue, hash table, set, map…… ...

  8. C++标准模板库(STL)和容器

    1.什么是标准模板库(STL)? (1)C++标准模板库与C++标准库的关系 C++标准模板库其实属于C++标准库的一部分,C++标准模板库主要是定义了标准模板的定义与声明,而这些模板主要都是 类模板 ...

  9. C++ STL 常用拷贝和替换算法

    C++ STL 常用拷贝和替换算法 copy() 复制 vector<int> vecIntA; vecIntA.push_back(1); vecIntA.push_back(3); v ...

随机推荐

  1. http://www.oschina.net/code/snippet_12_13918

    http://www.oschina.net/code/snippet_12_13918

  2. Linux文件夹、分区

    必须明确,硬盘分区的存在,是由硬盘的物理特性决定的,不会因为操作系统的不同而有所改变 所以不用对为根目录/挂载分区的同时还为/usr挂载分区感到惊讶   ====分区的概念==== 可以把一个硬盘比成 ...

  3. Agent是什么

    广义的Agent包括人类.物理世界的机器人和信息世界的软件机器人. 狭义的Agent专指信息世界中的软件机器人或称软件Agent. 1) 弱定义 Agent用来最一般地说明一个软硬件系统,具有四个特性 ...

  4. Android实现批量照片上传至server,拍照或者从相冊选择

    近期因为项目需求,须要完毕批量照片上传,折腾了一段时间,最终完毕了,达到了例如以下效果 主界面主要有GridView组成和button组成,当按下一个格点时,会调用相机或者相冊,拍照或者选择相冊照片, ...

  5. SVN回到历史版本--转载

    svn回到历史的某个版本 在代码的编写过程中,难免有些错误需要修改,或者想从以前的文件进行代码修改,这样就涉及到版本的追踪,如果你以前提交时日志写的非常清楚,那版本追踪回滚起来就事半功倍.得心应手.下 ...

  6. [Functional Programming] Pull Many Random Numbers in a Single State ADT Transaction

    We have the ability to select a single random card from a pile of twelve cards, but we would like to ...

  7. 【Java】Java_08 字符型与布尔值

    1.字符型(2个字节) 单引号用来表示字符常量.例如‘A’是一个字符,它与“A”是不同的,“A”表示含有一个字符的字符串 char 类型用来表示在Unicode编码表中的字符 Unicode编码被设计 ...

  8. 【Android进阶】怎样使用文件来保存程序中的数据

    在程序中.有非常多保存和获取数据的方法,本篇文章,主要介绍使用文件系统对程序中的数据进行保存和读取的操作 我直接写了一个帮助类,进行文件的写入和读取操作 /** * 用于在文件里保存程序数据 * * ...

  9. SDUTOJ 2775 小P的故事——奇妙的饭卡

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvUl9NaXNheWE=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...

  10. cygwin开发环境搭建与apt-cyg的应用

    1.Cygwin安装 http://www.cygwin.com/下载安装工具 详细安装过程參照http://jingyan.baidu.com/article/6b97984d83dfe51ca2b ...