stackqueuepriority_queuemapsetpair

======================================

stack:(栈)

包含:#include<stack>

定义:stack<value_type> S;

入栈:void push(const value_type& x)  如:S.push(i);

出栈:void pop()

取栈顶:value_type& top()  要注意的是,pop函数没有返回值,不能接收出栈的元素。要接收,要在pop之前使用top函数。

判栈空:bool empty()  返回 true 表示堆栈已空,false 表示堆栈非空。  如:if(!S.empty()){}

栈的大小:size_type size()   返回栈内元素的个数。

======================================

queue:(队列)

包含:#include<queue>

定义:queue<value_type> Q;

入队:void push(const value_type& x)       如:Q.push(i);

出队:void pop()

取队头:value_type& front()

取队尾:value_type& back()

判队空:bool empty()  返回 true 表示队已空,false 表示队非空。

队的大小:size_type size()   返回元素的个数。

======================================

priority_queue:(优先队列)

包含:#include<queue>

定义:priority_queue<value_type> Q;

入队:void push(const value_type& x)       如:Q.push(i);

出队:void pop()

取队头:value_top& top()

判队空:bool empty()  返回 true 表示队已空,false 表示队非空。

队的大小:size_type size()   返回元素的个数。

这个是大顶堆。

如果优先队列的元素类型是结构体,可以通过在结构体中重载“<“操作符的方法来修改优先队列的优先性。

如:bool operator<(const value_type &a) const;//重载小于号

======================================

map:(映射)

包含:#include<map>

定义:map<int,string> M;

插入元素:
M.insert(map<int,string>::value_type(2,”two”));//不覆盖
M[2]=”two”;//覆盖

判断元素存在:M.count(2)!=0//值为0表示不存在
M.find(2)!=M.end()//成立表示存在。效率高于上一条

查找元素:
M[2];//要先判断元素是否存在,返回存储的数据,若不存在会创建一个
M.find(2);//返回iterator类型,指向查找到的元素,若返回值等于M.end(),说明元素不存在。

删除元素:M.erase(2);//删除关键码为2的元素

iterator erase(iterator it); //通过一个条目对象删除

第一个元素:M.begin();

最后一个元素:M.end();

全部元素的遍历:
map<string,string>::iterator it;
for(it=M.begin();it!=M.end();it++)
    cout<<it->second<<endl;

it->first代表关键码,it->second代表存储的数据
======================================

set:(集合)

包含:#include<set>

定义:set<int> s;

插入元素:s.insert(1);

判断元素存在:s.count(1)!=0 //存在  也可以用s.find(1)!=s.end();效率较高

删除元素:s.erase(1);

清空所有元素:s.clear();

查找元素:s.find(1); //返回迭代器iterator

======================================

pair:

包含:#include<utility>   且 algorithm 和 map 也包含了这个头文件

定义:pair<int,int> p;

首元素:p.first

次元素:p.second

默认小于符:p1<p2 等价于 p1.first < p2.first  ||  ( !(p1.first < p2.first) && p1.second < p2.second)

      因此,组成pair的两种类型必须已经重载了小于号。

(还有其他。。。)

【ACM非算法部分】STL汇总的更多相关文章

  1. 【ACM非算法部分】综合篇

    从零开始系列,也为了更好的补缺补漏. ===================== 目录: scanf()函数 STL汇总 读入优化 =====================

  2. 【ACM非算法部分】scanf()函数

    scanf函数 格式说明符: %c    字符型 %d    十进制数 %i     读入十进制,八进制,十六进制数.输入的时候正常是十进制数,若输入0前缀的数将读入八进制,0x前缀读入16进制.若输 ...

  3. 【ACM非算法部分】读入优化

    今天做了ACdream的比赛才知道原来还有读入优化这一说.Orz 读入一个整数的时候这么写: int a; scanf("%d",&a); 和 int a; char c; ...

  4. ACM常用算法及练习(1)

    ACM常用算法及练习 第一阶段:练经典常用算法,下面的每个算法给我打上十到二十遍,同时自己精简代码,因为太常用,所以要练到写时不用想,10-15分钟内打完,甚至关掉显示器都可以把程序打出来. 1.最短 ...

  5. ACM常用算法及练习(2)

    ACM常用算法及练习 知识类型 重要度 容易度 应掌握度 典型题 其他           数据结构(5) 链表 ★★☆ ★★★ ★★☆     栈 stack ★★★ ★★★ ★★★ HLoj120 ...

  6. ACM主要算法

    ACM主要算法ACM主要算法介绍 初期篇 一.基本算法(1)枚举(poj1753, poj2965)(2)贪心(poj1328, poj2109, poj2586)(3)递归和分治法(4)递推(5)构 ...

  7. 基于OpenSLL的RSA加密应用(非算法)

    基于OpenSLL的RSA加密应用(非算法) iOS开发中的小伙伴应该是经常用der和p12进行加密解密,而且在通常加密不止一种加密算法,还可以加点儿盐吧~本文章主要阐述的是在iOS中基于openSL ...

  8. acm常见算法及例题

    转自:http://blog.csdn.net/hengjie2009/article/details/7540135 acm常见算法及例题  初期:一.基本算法:     (1)枚举. (poj17 ...

  9. 基于OpenSSL的RSA加密应用(非算法)

    基于OpenSSL的RSA加密应用(非算法) iOS开发中的小伙伴应该是经常用der和p12进行加密解密,而且在通常加密不止一种加密算法,还可以加点儿盐吧~本文章主要阐述的是在iOS中基于openSL ...

随机推荐

  1. Kattis - glitchbot 【DFS】

    Kattis - glitchbot [DFS] 题意 有一个机器人 刚开始在(0, 0),然后给出一个目标点,并且会给出一系列指令,但是其中会有一个指令是错误的.我们需要找出那个指令,并且改成正确的 ...

  2. js踩过的一些坑

    参考我的博客:http://www.isedwardtang.com/2017/08/29/js-bug/

  3. git-bash使用ctrl C无法终止nodemon的执行

    原因: git的bug 解决:git版本降级为2.10.0好了

  4. C++添加简单的日记记录

    #include<fstream>#include<iostream> using namespace std;//这是一种日记记录 b 种void LOG(char *tx, ...

  5. JavaScript传递的是引用的副本

    看例子 var test1 = function (args) { args.name = "lcc2"; args = { name: "lcc3" }; } ...

  6. Sybase:数据库检索的日期格式

    Sybase:数据库检索的日期格式 示例代码: --1,字符转日期 ' as date ),'yyyy/mm/dd'); ---结果:2018/03/09 --2,一年内第几天 ' as date ) ...

  7. tesseract编译各种 “锟斤拷” 等中文乱码 编译失败问题

    编译tesseract - ocr时 各种不通过 也很疑惑,完全按照官方指导来的啊 首先以为是vs的编码问题,随切换选项-切换Unicode或多编码字符集,但仍无效. 定位到乱码的文件,用notepa ...

  8. NGINX的IO模型详解

    普及: 用户空间与内核空间: 现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空间(虚拟存储空间)为4G(2的32次方).操作系统的核心是内核,独立于普通的应用程序,可以访问受保护的 ...

  9. windchill系统——导航器v1.0:思维导图

    总图 思维导图图片链接 http://www.edrawsoft.cn/viewer/public/s/7b3fc783493788

  10. Sudoku Solver, 求数独

    问题描述:填充数独表中空元素.空元素为'.' 算法分析:没填充一个数,都要看这个数所在的行,列,小矩阵是否合法.然后还要看整个数独表是否正确,而判断整个数独表只能通过递归,因为前一个结果的判断要依赖后 ...