C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法
每次忘记都去查,真难啊
/*
C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法
*/ /*
vector常用用法
*/
//头文件
#include<vector> //常用的初始化方法
vector<int> v; //直接定义一个整型元素的向量 且未声明长度,其中int的位置可以换成别的数据类型或者结构体等
vector<int> v(); //定义了10个整型元素的向量,其中每一个数都没有初值
vector<int> v(, ); //定义了10个整型元素的向量,并且为每个元素赋初值5 //常用的操作
v.back(); //返回最后一个元素
v.front(); //返回第一个元素
v.clear(); //清空v中的元素
v.empty(); //判断v是否为空,空则返回true,否则false
v.push_back(); //在最后的一个元素后插入5
v.size(); //返回v中的元素的个数 sort(v.begin(), v.end(), cmp); //sort排序,其中cmp部分与结构体等数据类型自定义排序时cmp相同用法 for(int i = ; i < v.size(); i++){ //遍历
printf("%d\n", v[i]);
} /*
map常用用法
*/
//头文件
#include<map> //常用操作
map<int, int> m; //初始化
m[] = ; //以数组形式插入值
m[] = ;
m[]++; //可以参与运算
m[] += ;
cout<<m[]<<endl;
cout<<m[]<<endl; /*
set常用用法 set中的元素自动从小到大排序,且合并重复元素
*/
//头文件
#include<set> //常用操作
set<int>s; //定义
s.insert(x); //插入数值
s.clear(); //删除set容器中的所有的元素
s.empty(); //判断set容器是否为空 set<int>::iterator it; //遍历
for(it = s.begin(); it != s.end(); it++)
{
printf("%d\n", *it);
} //s.end()没有值
cout<<"s.begin() "<<*s.begin()<<endl;
//lower_bound()--返回指向大于(或等于)某值的第一个元素的迭代器
cout<<"lower_buond 3 "<<*s.lower_bound()<<endl;
//upper_bound()--返回大于某个值元素的迭代器
cout<<"upper_bound 3 "<<*s.upper_bound()<<endl;
//find()--返回一个指向被查找到元素的迭代器
cout<<"find(3) "<<*s.find()<<endl;
cout<<"s.size() "<<s.size()<<endl; /*
queue常用用法
*/
//头文件
#include<queue> //常用操作对于普通队列来说
queue<int> q; //定义一个队列
q.front(); //获取队首元素
q.pop(); //删除队首元素
q.empty(); //判断队列是否为空
q.push(); //向队列中加入元素 //priority_queue
priority_queue<int> q; //定义一个优先队列
q.top(); //获取队列中最大元素(首个)
q.pop(); //删除最大元素(队首)
q.push(x); //向队列中加入元素
q.empty(); //判断优先队列是否为空 //对于结构体而言,需要重载小于号(优先队列按照从大到小排序)
priority_queue<Node> q; struct Node{
int a, b;
bool operator < (const Node & x) const
{
return a > x.a;
}
}; /*
stack常用用法
*/
//头文件
#include<stack> //常用操作
stack<int> s; //定义一个栈
s.pop(); //删除栈顶元素
s.top(); //获取栈顶元素
s.empty(); //判断栈是否为空
s.push(); //向栈中压入5
C/C++解题常用STL大礼包 含vector,map,set,queue(含优先队列) ,stack的常用用法的更多相关文章
- ACM竞赛常用STL(一)
全排列函数next_permutation STL 中专门用于排列的函数(可以处理存在重复数据集的排列问题) 头文件:#include <algorithm> using namespac ...
- C++标准模板库(STL)之Vector
在C中,有很多东西需要自己实现.C++提供了标准模板库(Standard Template Libray,STL),其中封装了很多容器,不需要费力去实现它们的细节而直接调用函数来实现功能. 具体容器链 ...
- C++常用STL
目录 C++ 常用STL整理 容器和配接器 list(链表) stack(栈) queue(队列) priority_queue(优先队列) set(集合) vector(向量) map&&a ...
- STL模板整理 vector
一.什么是标准模板库(STL)? 1.C++标准模板库与C++标准库的关系 C++标准模板库其实属于C++标准库的一部分,C++标准模板库主要是定义了标准模板的定义与声明,而这些模板主要都是 类模板, ...
- 转:用STL中的vector动态开辟二维数组
用STL中的vector动态开辟二维数组 源代码:#include <iostream>#include <vector>using namespace std;int mai ...
- STL中的Vector相关用法
STL中的Vector相关用法 标准库vector类型使用需要的头文件:#include <vector>. vector 是一个类模板,不是一种数据类型,vector<int> ...
- [知识点]C++中STL容器之vector
零.STL目录 1.容器之map 2.容器之vector 3.容器之set 一.前言 关于STL和STL容器的概念参见STL系列第一篇——map(见上).今天介绍第二个成员——vector. 二.用途 ...
- (转)C++ STL中的vector的内存分配与释放
C++ STL中的vector的内存分配与释放http://www.cnblogs.com/biyeymyhjob/archive/2012/09/12/2674004.html 1.vector的内 ...
- C++STL中的vector的简单实用
[原创] 使用C++STL中的vector, #include <stdio.h> #include<stdlib.h> #include<vector> usin ...
随机推荐
- Spring Cloud @RefreshScope 原理是什么?
要清楚RefreshScope,先要了解Scope Scope(org.springframework.beans.factory.config.Scope)是Spring 2.0开始就有的核心的概念 ...
- 记一次Pr中视频蜜汁卡顿往复和解决方法
目录 问题 换素材的起因 灵异素材 无端联想 解决 问题 换素材的起因 本来视频剪了一晚剪完了,导出一看,好家伙,糊到上世纪.原来素材的像素大小都没法看,这视频素材我是从别人U盘拷过来的,可他竟然是用 ...
- [Gamma]Scrum Meeting#10
github 本次会议项目由PM召开,时间为6月5日晚上10点30分 时长15分钟 任务表格 人员 昨日工作 下一步工作 木鬼 撰写博客,组织例会 撰写博客,组织例会 swoip 前端显示屏幕,翻译坐 ...
- 【java】使用jsp命令查看系统中java运行的程序及进程号
对于java独立运行的程序,他们在进程中的名字都是 Java(TM) Platform SE binary,如图 我们想知道这个进程运行的是哪个程序,怎么办呢? 答案是:可以在命令行下,运行:jps命 ...
- cad.net IExtensionApplication接口的妙用 分开写"启动运行"函数
cad提供的 IExtensionApplication 接口 是不能实现一次以上的,那么这给编写代码带来了一种不好的情况是,每次都要去修改实现这个接口的类, 如果是一个小的测试功能,你又要去动前面的 ...
- Logstash测试的时候,报Error occurred during initialization of VM,Could not reserve enough space for object heap
今天配置Logstash的时候,启动输入logstash ‐e 'input { stdin { } } output { stdout {} }'就开始报错了,Error occurred duri ...
- Java核心技术-读书笔记
基本语法 Java中的所有函数都属于某个类的方法 Java没有任何无符号的int.long.short 或 byte 类型 浮点数值不适用于无法接受舍入误差的金融计算中,比如2.0-1.1不会输出想要 ...
- 【数据结构与算法】线性表操作(C语言)
#include <stdio.h> #include <stdlib.h> #define OK 1 #define NO 0 #define MAXSIZE 20 type ...
- @Valid参数验证 BindingResult result 的使用
1.首先导入依赖包bean-validator.jar2.在实体类上面写一些相关的验证信息:可以搜索更多的一些验证方式,这只是一部分 可以参考:点击打开链接http://blog.csdn.net/c ...
- [Atcoder ARC103D]Robot Arms
题目大意:平面上有$n$个点,要求你构造$m$条边(满足$m\leqslant40$),使得可以从原点到达给定的$n$个点(边必须平行于坐标轴).并要求输出每一条边的方向,每条边必须都使用,无解输出$ ...