2020.2.27——STL初步
注:本文主要针对STL中的常用的操作进行总结
目录:
1.swap
2.sort
3.reverse
4.min,max(比较简单,暂且略过)
5._gcd
6.lower_bound && upper_bound
7.next_permutation
8.unique
1.swap
(1)目的:交换两个数的值
(2)手写 代码实现:
#include<iostream>
using namespace std;
inline void swap(int &x,int &y){
int temp;
temp=x;
x=y;
y=temp;
}
int main(){
int a,b;
cin>>a>>b;
swap(a,b);
cout<<a<<" "<<b;
return 0;
}
(3)STL使用
对a,b两个数进行swap操作
swap(a,b);
注:此处STL相对较慢,而手写代码量小,推荐自行手写
2.sort
(1)目的:对数组元素进行排序
注:非自定义cmp时,默认为从小到大排序
(2)使用:
(其实手写快排比这个快。。。。。。)
sort(start,end,cmp); //cmp可不填
//start是排序起始位置,end即排序结束位置,cmp即排序方式
//如:sort(a,a+10)
3.reverse
(1)目的:
用于反转在[a,b)范围内的数据顺序(其包括a指的元素,但不包括b指的元素);
(2)使用:
reverse(start,end);
/* e.g.
char s[]="abcdefgh"
reverse(s,s+strlen(s));
*/
//结果为:hgfedcba
//start为起始位置,end为结束位置
4.min,max(略过。。。。。。)
5.__gcd
(1)目的:求两个数的最大公因数
(2) 手写 版代码
inline int gcd(int x,int y){
if(y==0) return x;
else return(gcd(y,x%y));
//return y==0?x:gcd(y,x%y);
}
(3)使用:
__gcd(a,b); //注:gcd前需要添加两个下划线
这里真的推荐手写,毕竟代码量很小,STL那么慢。。。。。。
6.lower_bound && upper_bound
前言:start指起始位置,end指结束位置,k指要查找的数值
(1)lower_bound()
使用:lower_bound(start,end,k)
目的:从start到end-1二分查找** 第一个大于或等于k的数字 ** ,返回该数字的地址,不存在则返回end。用返回的地址减去起始地址start,得到下标。
(2)upper_bound()
使用:upper_bound(start,end,k)
目的:从数组的start位置到end-1位置二分查找** 第一个大于k的数字 **,返回该数字的地址,不存在则返回end。用返回的地址减去起始地址start,得到下标。
7.next_permutation
(1)目的:对数组进行全排列
注:在进行next_permutation操作之前,必须保证要操作的数组是有序的
(2)使用:
bool next_permutation(start,end)
//和sort,reverse等使用方法大致一样
8.unique
(1)目的:去除容器内相邻的重复的元素(只保留一个)
注:此处的“去除”指把重复元素移到容器最后。
通常使用前容器应该要是有序的(不是必要条件)。
(2)使用:
要想真正去除重复元素还需要使用erase()函数
unique(start,end);
//与sort等使用格式一样,不多赘述
//Example:unique(a,a+5);
-------------------------------------------------THE END------------------------------------------
2020.2.27——STL初步的更多相关文章
- HomeLede 2020.5.27更新 UPnP+NAS+多拨+网盘+DNS优化+帕斯沃/Clash 无缝集成+软件包
交流群:QQ 1030484865 电报 t.me/t_homelede 固件说明 基于Lede OpenWrt R2020.5.20版本(源码截止2020.5.27)及若干自行维护的软件包 结合 ...
- STL初步学习(vector)
前文 初三下学期进入新的学习,对于前两年的学习内容因为各种原因 上课打游戏,睡觉,看视频 已经遗忘,忘记如何使用,算是重新学习一次信息学,希望能尽快将以前的内容弥补上来,争取能在CSP-2020取得一 ...
- 【STL初步】不定长数组:vector + 集合:set + 映射:map
一.vector 为了节省空间,有时我们会使用动态数组vector. 定义动态数组 vector<类型名>变量名 vector<int>que //定义que为一个int类型的 ...
- (STL初步)不定长数组:vector
STL是指C++的标准模板库.(存储着一些常用的算法和容器) vector是一个不定长数组.它把一些常用的操作”封装“在vector类型内部. 例如,a是一个vector.1对元素的操作有,可以用a. ...
- STL初步学习(queue,deque)
4.queue queue就是队列,平时用得非常多.栈的操作是只能是先进先出,与栈不同,是先进后出,与之后的deque也有区别.个人感觉手写队列有点麻烦,有什么head和tail什么的,所以说 STL ...
- STL初步学习(set)
2.set set可以看作一个集合,可以实现自动排序(升序)和去重 在许多题目中,都可以使用这个模板库,减少很多操作,例如P1923 第k小数,当然,这道题有很多奇奇怪怪的做法,分值都不同,之后会讲解 ...
- IntelliJ IDEA 2020.2.3永久破解激活教程 - 2020.10.27
申明:本教程 IntelliJ IDEA 破解补丁.激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除 不花钱 的方式 IDEA 2020.2 激活到 2089 年 注意:教程适 ...
- 2016 - 1 - 27 javaScrip初步(一)
<head> </head> <body> <!-- The onclick attribute is the code that happens when ...
- stl 初步的使用
1.sort 和 lower_bound 例如 marble https://uva.onlinejudge.org/index.php?option=com_onlinejudg ...
随机推荐
- 智能指针 unique_ptr
unique_ptr 不共享它的指针.它无法复制到其他 unique_ptr,无法通过值传递到函数,也无法用于需要副本的任何标准模板库 (STL) 算法. 1.不能进行复制构造和赋值操作(unique ...
- 数据结构和算法(Golang实现)(4)简单入门Golang-结构体和方法
结构体和方法 一.值,指针和引用 我们现在有一段程序: package main import "fmt" func main() { // a,b 是一个值 a := 5 b : ...
- OkHttp 优雅封装 HttpUtils 之 上传下载解密
曾经在代码里放荡不羁,如今在博文中日夜兼行,只为今天与你分享成果.如果觉得本文有用,记得关注我,我将带给你更多. 还没看过第一篇文章的欢迎移步:OkHttp 优雅封装 HttpUtils 之气海雪山初 ...
- @SessionAttributes 的使用
@SessionAttributes 注解只用作用在 类 上,作用是将指定的 Model 的键值对保存在 session 中.可以让其他请求共用 session 中的键值对. 指定保存的属性名 作用是 ...
- 【题解】P1291 百事世界杯之旅 - 期望dp
P1291 [SHOI2002]百事世界杯之旅 声明:本博客所有题解都参照了网络资料或其他博客,仅为博主想加深理解而写,如有疑问欢迎与博主讨论✧。٩(ˊᗜˋ)و✧*。 题目描述 "--在 \ ...
- Springboot:IDEA重调安装依赖窗口(二)
Settings-Plugins 搜索Editstarters: 安装完插件 重启idea: 查看安装是否成功: 在pom.xml 右键: 选择热部署依赖 点击ok进行自动装配: 热部署依赖环境已经配 ...
- SQL Server 之T-SQL基本语句 (3)
继续来用例子总结sql基本语句用法. 在这里在建一个表:课 课程名 上课时间 数学 周一 数学 周二 数学 周三 语文 周一 语文 周二 英语 周一 数据分组:GROUP BY select 课程 ...
- Redis学习与应用-位图
什么是位图 位图bitmap是通过一个bit来表示某个元素对应的值或者状态,是由一组bit位组成,每个bit位对应0和1两个状态,虽然内部还是采用string类型进行存储,但是redis提供了直接操作 ...
- 实现Nginx Upload 模块 功能上传文件。
分析(也许我表达的让人难以理解,但是我想说一句,直接实践是最好的.....): 一.Ningx 上传( 1.安装Nginx 的模块文件(upload):https://www.nginx.com/re ...
- 2019-2020-1 20199326《Linux内核原理与分析》第九周作业
进程的切换和系统的一般执行过程 中断 中断在本质上都是软件或者硬件发生了某种情形而通知处理器的行为,处理器进而停止正在运行的指令流(当前进程),对这些通知做出相应反应,即转去执行预定义的中断处理程序( ...