先说一下  一边要用到算法的东西一般要加#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函数(持续更新的更多相关文章

  1. php 常用的好函数(持续更新)

    parse_url parse_url $url = "http://www.electrictoolbox.com/php-extract-domain-from-full-url/&qu ...

  2. iOS:开发常用GitHub开源项目(持续更新)

    IOS开发常用GitHub开源项目(持续更新) 数据类 开源库 作者 简介 AFNetworking Mattt 网络请求库 ASIHTTPRequest pokeb 网络请求库 Alamofire ...

  3. PHP的常用函数 持续更新

    PHP的常用函数 前言: 由于害怕遗忘,故在此记录下常用的php函数,以便复习 1 define函数 作用:定义常量 用法 <?php define('a',100); ?> 2 intv ...

  4. Android开发中常用的库总结(持续更新)

    这篇文章用来收集Android开发中常用的库,都是实际使用过的.持续更新... 1.消息提示的小红点 微信,微博消息提示的小红点. 开源库地址:https://github.com/stefanjau ...

  5. sqlserver常用知识点备忘录(持续更新)

    背景 一个项目的开发,离不开数据库的相关操作,表/视图设计,存储过程,触发器等等数据库对象的操作是非常频繁的.有时候,我们会查找系统中类似的代码,然后复制/粘贴进行再进行相应的修改.本文的目的在于归纳 ...

  6. Android中常用开发工具类—持续更新...

    一.自定义ActionBar public class ActionBarTool { public static void setActionBarLayout(Activity act,Conte ...

  7. 常用linux,DOS命令——持续更新

    cd 文件夹名 进入某个文件夹 cd ../ 退出该级目录进入上一级 cd ../../ 退出该级目录进入上上级 cd ../../demo 退出该级目录进入上上级的目录 d: 回车 进入d盘 ls ...

  8. STL的常用用法、函数汇总(不定时更新)

    隶书文字为原创. 1.vector 在c++中,vector是一个十分有用的容器,下面对这个容器做一下总结. 1 基本操作 (1)头文件#include<vector>. (2)创建vec ...

  9. 记录 C++ STL 中 一些好用的函数--持续更新 (for_each,transform,count_if,find_if)

    在日常的编程中,有这么几种操作还是比较常见的: 把一组数据都赋值成一个数,在一组数据中查找一个数,统计一组数据中符合条件的数等等. 一般的写法可以用循环,没有什么是循环不能搞定的.假如在这里怎么用介绍 ...

随机推荐

  1. VueJs - 世界地图(根据返回国家value值的大小来展示颜色的深浅分布)

    一.实现功能 1.画出世界各国的世界地图 2.根据返回name->国家全称.value->数量,渲染对比世界各国成功的国家,予以值域范围的高亮 3.滑入国家地图,出现tooltip框,提示 ...

  2. CSS基础语法(一) CSS的3种引入

    CSS样式表 CSS可算是网页设计的一个突破,它解决了网页界面排版的难题.可以这么说,HTML的Tag主要是定义网页的内容(Content),而CSS决定这些网页内容如何显示(Layout). Web ...

  3. Android(java)学习笔记37:String类型的面试题

    1. String类型面试题: package cn.itcast_02; /* * String s = new String(“hello”)和String s = “hello”;的区别? * ...

  4. ASP.NET SignalR 与LayIM配合,轻松实现网站客服聊天室(四) 添加表情、群聊功能

    休息了两天,还是决定把这个尾巴给收了.本篇是最后一篇,也算是草草收尾吧.今天要加上表情功能和群聊.基本上就差不多了,其他功能,读者可以自行扩展或者优化.至于我写的代码方面,自己也没去重构.好的,我们开 ...

  5. Cesium.js学习第二天(立方体)

    var viewer = new Cesium.Viewer('cs'); viewer.entities.add({//图标 position: Cesium.Cartesian3.fromDegr ...

  6. 【luogu P2146 [NOI2015]软件包管理器】 题解

    题目链接:https://www.luogu.org/problemnew/show/P2146 变量名真毒瘤 我真的再也不把l,left,r,right弄反了 反向思维更好做一些 #include ...

  7. 【luogu P3865 ST表】 模板

    跟忠诚是一样滴,不过是把min改成max就AC了.模板题. #include <cstdio> #include <algorithm> using namespace std ...

  8. 转载:C/C++ typedef用法

    原文链接:http://www.cnblogs.com/ggjucheng/archive/2011/12/27/2303238.html 引言 typedef 声明,简称 typedef,为现有类型 ...

  9. 发布Android程序

    这个选项的意思是说,要使用.NET 2.0的完整版本,而非其子集. 下午发布Apk,一直报错,解决好了,忘记选这个了,以前都记得,明天再去公司发布去

  10. spring boot整合mybatis查询数据库返回Map字段为空不返回解决

    1.出现问题原因原因1:mybatis的配置即mapper返回映射配置. 原因2:jackson的配置即@ResponseBody序列化配置. 2.解决方式步骤1:解决原因1 mybatis: con ...