STL 一些常用的STL函数(持续更新
先说一下 一边要用到算法的东西一般要加#include<algorithm>头文件
一、栈和队列
1 栈 :一种线性表
特点 后进先出
头文件 #include<stack>
声明 stack< 类型 > sk(变量); 注意 这里的类型 如果是char只能是单个字符 如果要存字符串要用string
- sk.push(); 向里存 写在括号里
- sk.pop(); 出栈 把最上面的出栈(即所谓的先进后出 注意 这里的不能赋值给别的变量 括号里也不能写东西
- data = sk.top(); 取出栈顶的元素赋值给一个变量 (不出栈
- size = sk.size(); 栈里元素的个数
- sk.empty(); 判定栈是否为空
注意 要清空栈 没有函数 要自己写
2 队列
特点 先进先出 (类似于排队买饭
头文件 #include<queue>
声明 queue< 类型 > q(变量);
- q.push(); 向里存 写在括号里
- q.pop(); 出队列 把队首的出队列(即所谓的先进先出 注意 这里的不能赋值给别的变量 括号里也不能写东西
- data = q.front(); 获得队列首的元素赋值给一个变量 (不出队列
- q.back(); 获得队尾的值 同q.front();
- size = q.size(); 队列里元素的个数
- q.empty(); 判定队列是否为空
- q.clear(); 清空队列
3 双端队列
特点 两端都可以进出
头文件 #include<deque>
声明 deque< 类型 > dq(变量);
- dq.push_front(); 向双端队列首存 写在括号里
- dq.push_back(); 向双端队列尾存 写在括号里
- dq.pop_front(); 将双端队列的队首元素出双端队列
- dq.pop_back(); 将双端队列的队尾元素出双端队列
- data = dq.front(); 获得双端队列首的元素赋值给一个变量 (不出双端队列
- q.back(); 获得双端队列尾的值 同q.front();
- dq.empty(); 判定双端队列是否为空
- dq.clear(); 清空双端队列
4 优先队列(暂时不会。。
特点 自动按升降序排序
头文件 #include<queue>
priority_queue < 类型 > q; 默认大小排序从大到小
priority_queue < 类型 ,vector <类型>, greater<类型> > q; 默认大小排序从小到大
priority_queue < 类型 ,vector <类型>, less<类型> > q; 默认大小排序 从大到小
- q.push(); 向里存 写在括号里
- q.pop(); 出队列 队首
- data = q.top(); 取出队首的元素赋值给一个变量 (不出栈
- size = q.size(); 队列里元素的个数
- q.empty(); 判定队列是否为空
5 unique( , ) 去重 lower_bound() upper_bound()
6 set
set < 类型 > q; 集合 自带排序 迭代器
q.insert(); 插入
q.erase(); 插入
q.lower_bound();
迭代器 set < 类型 > :: iterator it;
it = q.begain();
for(it = q.begain() ; it ! = q.end() ; it++)
*it
两个查询
it=q.find(); 返回迭代器
q.count(); 返回0或1
运算符重载
6 map
map< 类型,类型 > m; 相当于将离散的数连续的排列在一个数组中 map< , >::iterator it; (*it).first;是键 (*it).second; 是值;
键 值
查找 m.find();
m.count();
注意 if(m[6]!=0) 是可以的 但是 这样写如果没有会往m里存 可能会将原来的数给压下去
map可以是好几个键对应一个值
对于遍历 正着遍历(从小到大) for(it=m.begin();it!=m.end();it++)
反着遍历(从大到小) for(it=m.rbegin();it!=m.rend();it++)
这里的it无论正反好像只支持++, - -的操作不支持+1,-1这样的操作
7 pair 可以重
STL 一些常用的STL函数(持续更新的更多相关文章
- php 常用的好函数(持续更新)
parse_url parse_url $url = "http://www.electrictoolbox.com/php-extract-domain-from-full-url/&qu ...
- iOS:开发常用GitHub开源项目(持续更新)
IOS开发常用GitHub开源项目(持续更新) 数据类 开源库 作者 简介 AFNetworking Mattt 网络请求库 ASIHTTPRequest pokeb 网络请求库 Alamofire ...
- PHP的常用函数 持续更新
PHP的常用函数 前言: 由于害怕遗忘,故在此记录下常用的php函数,以便复习 1 define函数 作用:定义常量 用法 <?php define('a',100); ?> 2 intv ...
- Android开发中常用的库总结(持续更新)
这篇文章用来收集Android开发中常用的库,都是实际使用过的.持续更新... 1.消息提示的小红点 微信,微博消息提示的小红点. 开源库地址:https://github.com/stefanjau ...
- sqlserver常用知识点备忘录(持续更新)
背景 一个项目的开发,离不开数据库的相关操作,表/视图设计,存储过程,触发器等等数据库对象的操作是非常频繁的.有时候,我们会查找系统中类似的代码,然后复制/粘贴进行再进行相应的修改.本文的目的在于归纳 ...
- Android中常用开发工具类—持续更新...
一.自定义ActionBar public class ActionBarTool { public static void setActionBarLayout(Activity act,Conte ...
- 常用linux,DOS命令——持续更新
cd 文件夹名 进入某个文件夹 cd ../ 退出该级目录进入上一级 cd ../../ 退出该级目录进入上上级 cd ../../demo 退出该级目录进入上上级的目录 d: 回车 进入d盘 ls ...
- STL的常用用法、函数汇总(不定时更新)
隶书文字为原创. 1.vector 在c++中,vector是一个十分有用的容器,下面对这个容器做一下总结. 1 基本操作 (1)头文件#include<vector>. (2)创建vec ...
- 记录 C++ STL 中 一些好用的函数--持续更新 (for_each,transform,count_if,find_if)
在日常的编程中,有这么几种操作还是比较常见的: 把一组数据都赋值成一个数,在一组数据中查找一个数,统计一组数据中符合条件的数等等. 一般的写法可以用循环,没有什么是循环不能搞定的.假如在这里怎么用介绍 ...
随机推荐
- 【Leetcode】【Easy】Remove Nth Node From End of List
Given a linked list, remove the nth node from the end of list and return its head. For example, Give ...
- 防止HTML出现滚动条时页面的抖动
<html> <style> * { padding: 0; margin: 0; } body { font: 40px fantasy; } .container { wi ...
- 小故事学设计模式之Observer : (三) 老婆帮忙订机票
(IT的事就是过场多,过场多了就容易忘,所以我们不妨看一个记一个,这也是一个办法,顺便还能跟同行们交流一下) 要和老婆一起回老家了, 成都离我们安徽太远, 两个人飞一下过去就要花掉近三千块, 于是我 ...
- 解决svn中“工作副本已经锁定”,或者svn清理失败的解决方法
刚开始遇到这个问题还以为是没有插网线的原因,客户端和服务器都在我的电脑上,但是更新和提交都执行不了,以为是没有插网线就没把这个小问题放在心上,今早上还是这样,就不得不解决一下了. 更新或者提交前要执行 ...
- LightOJ-1028 Trailing Zeroes (I)---因子数目
题目链接: https://cn.vjudge.net/problem/LightOJ-1028 题目大意: 一个十进制数1≤n≤1012,现在用base进制来表示,问有多少种表示方法使得最后一位上的 ...
- ACM-ICPC (10/20)
B. Bakery time limit per test 2 seconds memory limit per test 256 megabytes input standard input out ...
- 课堂笔记——while循环
用 while循环 1.100以内所有数的和 static void Main1(string[] args) //不是自己做的 { //100以内所有数的和 ; ; //初始条件 ) //循环条件 ...
- POJ 3565 Ants 【最小权值匹配应用】
传送门:http://poj.org/problem?id=3565 Ants Time Limit: 5000MS Memory Limit: 65536K Total Submissions: ...
- 搭建 webpack + React 开发环境
说在开头 上个月断断续续的在研究webpack的配置,但是很多网上的文章基本上都是只说了开发环境的配置,而忽略了生产环境的配置.大致研究了一下门路,然后就来写一篇随笔让自己能在以后能有个地方可以做参考 ...
- 学习Apache的mod rewrite、access写法
Apache的mod_rewrite是提供了强大URL操作的杀手级的模块,可以实现几乎所有你梦想的URL操作类型,其代价是你必须接受其复杂性,因为mod_rewrite的主要障碍就是初学者不容易理解和 ...