1.vector

  • 包含头文件#include<vector>
  • 使用命名域using namespace std
  • 定义元素类型为T的vector vector<T> vec
  • 增:向vector中添加元素a,使用成员函数vec.push_back(a),元素a被加到向量末尾
  • 删:vec.pop_back()删除最后一个元素
  • 取:vec[i] 可以取第i个元素,下标从0开始;取第一个元素vec.begin()vec.end()是取最后一个的下一个
  • 下图为成员函数

2.string

  • 包含头文件#include<string>
  • 使用命名域using namespace std
  • 获取字符串长度:str.length()
  • 查找:str.find(a,k) a可以是字符也可以是字符串,k为int。返回从k开始,a首次匹配str中的位置,无匹配则返回-1,k若缺省则从0开始。
  • 字符串倒置:reverse(str.begin(), str.end())
  • 截取子串:str1 = substr(pos,n)返回str中起始位置为pos,长度为n的字符串,n若缺省则到结尾
  • 追加字符串:可以用str.append(str1)或者str+=str1这个重载运算符来实现向str的末尾追加str1
  • 比较字符串:str.compare(str1)相等返回0,str大于str1返回1,否则返回-1。也可以直接用>,<,=

3.stack

  • 包含头文件#include<stack>
  • 使用命名域using namespace std
  • 定义元素为T类型的vector stack<T> sta
  • 成员函数表如下图

4.list

5.queue

  • 定义一个queue的变量 queue<Type> M
  • 查看是否为空范例 M.empty() 是的话返回1,不是返回0;
  • 从已有元素后面增加元素 M.push()
  • 输出现有元素的个数 M.size()
  • 显示第一个元素 M.front()
  • 显示最后一个元素 M.back()
  • 清除第一个元素 M.pop()

6.map

  • 包含头文件#include<map>
  • 使用命名域using namespace std
  • map中的元素是一个pair,定义键为T1类型,值为T2类型的map map<T1, T2> m
  • 增:插入数据有以下四种方法
  //以下例子中m为map<String,int>类型
m["a"] = 1; m.insert(map<string, int>::value_type("a",1)); m.insert(pair<string,int>("c",3)); m.insert(make_pair("d",4));
  • 根据键值取元素和修改元素对应的值
 int i = m["a"];  //取到键值"a"对应的值

 map<int, string>::iterator iter;  

 iter = m.find("a"); // 返回数据所在位置的迭代器,如果map中没有要查找的数据,则返回的迭代器等于end函数返回的迭代器
int i = iter->second; //用迭代器取到对应的值
iter->second=j; //修改迭代器对应的值

7.set

C++ STL常用容器基本用法汇总的更多相关文章

  1. STL常用容器用法

    -1. 本文章中所有函数原型均为C++98的标准. 通用的操作 //遍历容器--以vector,map为例 vector<int> vt; map<int,int> mp; f ...

  2. C++中STL常用容器的优点和缺点

    我们常用到的STL容器有vector.list.deque.map.multimap.set和multiset,它们究竟有何区别,各自的优缺点是什么,为了更好的扬长避短,提高程序性能,在使用之前需要我 ...

  3. C++ STL常用容器浅析

    首先要理解什么是容器,在C++中容器被定义为:在数据存储上,有一种对象类型,它可以持有其它对象或指向其它对象的指针,这种对象类型就叫做容器.简单来说 容器就是包含其他类的对象们的对象,当然这种(容器) ...

  4. STL常用容器使用方法

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

  5. 【C++】STL常用容器总结之五:双端队列deque

    6.双端队列deque 所谓的deque是”double ended queue”的缩写,双端队列不论在尾部或头部插入元素,都十分迅速.而在中间插入元素则会比较费时,因为必须移动中间其他的元素.双端队 ...

  6. C++中STL常用容器的区别(转)

    我们常用到的STL容器有vector.list.deque.map.multimap.set和multiset,它们究竟有何区别,各自的优缺点是什么,为了更好的扬长避短,提高程序性能,在使用之前需要我 ...

  7. STL源代码学习--vector用法汇总

    一.容器vector 使用vector你必须包含头文件<vector>: #include<vector> 型别vector是一个定义于namespace std内的templ ...

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

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

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

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

随机推荐

  1. 你还在为如何区分ASCII编码、GB2312编码、Unicod、UTF-8编码而烦恼吗,一篇文章让你柳暗花明

    字符编码 我们已经讲过了,字符串也是一种数据类型,但是,字符串比较特殊的是还有一个编码问题. 因为计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理.最早的计算机在设计时采用8个比特 ...

  2. 利用scrapy模拟登录知乎

    闲来无事,写一个模拟登录知乎的小demo. 分析网页发现:登录需要的手机号,密码,_xsrf参数,验证码 实现思路: 1.获取验证码 2.获取_xsrf 参数 3.携带参数,请求登录 验证码url : ...

  3. PyTorch官方中文文档:torch.optim

    torch.optim torch.optim是一个实现了各种优化算法的库.大部分常用的方法得到支持,并且接口具备足够的通用性,使得未来能够集成更加复杂的方法. 如何使用optimizer 为了使用t ...

  4. RobotFramework自动化测试框架的基础关键字(三)

    1.1.1        如何定义一个字典 此处我们说的字典,其实就等同于python语言中的字典,和列表一样,字典也是python语言中非常常用的一种数据结构,也类似于Java 语言中的Map. 在 ...

  5. 说说你对用SSH框架进行开发的理解

    SSH框架指的是Struts,Spring,Hibernate.其中,Struts主要用于流程控制:Spring的控制反转能祈祷解耦合的作用:Hibernate主要用于数据持久化.

  6. 【BZOJ1500】【NOI2005】维修数列(Splay)

    [BZOJ1500][NOI2005]维修数列(Splay) 题面 不想再看见这种毒瘤题,自己去BZOJ看 题解 Splay良心模板题 真的很简单 我一言不发 #include<iostream ...

  7. POJ 2195 Going Home (费用流)

    题面 On a grid map there are n little men and n houses. In each unit time, every little man can move o ...

  8. HDU4812

    树分治 求逆元请递推,不然会TLE 开桶记录即可 注意常数 # pragma comment(linker,"/STACK:102400000,102400000") # incl ...

  9. freemind中内容变成html转义字符解决方法

    在使用freemind的时候,没有正常关闭,导致原来的内容变成下面这样: <html> <body> <p> <b>查询所有</b> < ...

  10. 关系型数据库工作原理-查询优化器之索引(翻译自Coding-Geek文章)

    本文翻译自Coding-Geek文章:< How does a relational database work>.原文链接:http://coding-geek.com/how-data ...