注:本文主要针对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初步的更多相关文章

  1. HomeLede 2020.5.27更新 UPnP+NAS+多拨+网盘+DNS优化+帕斯沃/Clash 无缝集成+软件包

    交流群:QQ 1030484865 电报 t.me/t_homelede   固件说明 基于Lede OpenWrt R2020.5.20版本(源码截止2020.5.27)及若干自行维护的软件包 结合 ...

  2. STL初步学习(vector)

    前文 初三下学期进入新的学习,对于前两年的学习内容因为各种原因 上课打游戏,睡觉,看视频 已经遗忘,忘记如何使用,算是重新学习一次信息学,希望能尽快将以前的内容弥补上来,争取能在CSP-2020取得一 ...

  3. 【STL初步】不定长数组:vector + 集合:set + 映射:map

    一.vector 为了节省空间,有时我们会使用动态数组vector. 定义动态数组 vector<类型名>变量名 vector<int>que //定义que为一个int类型的 ...

  4. (STL初步)不定长数组:vector

    STL是指C++的标准模板库.(存储着一些常用的算法和容器) vector是一个不定长数组.它把一些常用的操作”封装“在vector类型内部. 例如,a是一个vector.1对元素的操作有,可以用a. ...

  5. STL初步学习(queue,deque)

    4.queue queue就是队列,平时用得非常多.栈的操作是只能是先进先出,与栈不同,是先进后出,与之后的deque也有区别.个人感觉手写队列有点麻烦,有什么head和tail什么的,所以说 STL ...

  6. STL初步学习(set)

    2.set set可以看作一个集合,可以实现自动排序(升序)和去重 在许多题目中,都可以使用这个模板库,减少很多操作,例如P1923 第k小数,当然,这道题有很多奇奇怪怪的做法,分值都不同,之后会讲解 ...

  7. IntelliJ IDEA 2020.2.3永久破解激活教程 - 2020.10.27

    申明:本教程 IntelliJ IDEA 破解补丁.激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除 不花钱 的方式 IDEA 2020.2 激活到 2089 年 注意:教程适 ...

  8. 2016 - 1 - 27 javaScrip初步(一)

    <head> </head> <body> <!-- The onclick attribute is the code that happens when ...

  9. stl 初步的使用

    1.sort 和  lower_bound 例如     marble      https://uva.onlinejudge.org/index.php?option=com_onlinejudg ...

随机推荐

  1. 7.2 java 类的定义和使用

    /* * 类的定义: * 类是用来描述现实世界的事物的 * * 事物: * 属性 事物的描述信息 * 行为 事物能够做什么 * * 类是如何和事物进行对应的呢? * 类: * 成员变量 * 成员方法 ...

  2. C++实现双向循环链表

    本次博文是关于利用C++模板的方式实现的双向循环链表以及双向循环链表的基本操作,在之前的博文C++语言实现双向链表中,已经给大家分析了双向循环链表的结构,并以图示的方式给大家解释了双向循环链表的基本操 ...

  3. Go语言 可变参数

    最近与同事讨论时,提到Go语言的可变参数,之前没有总结过相关知识点,今天我们介绍一下Go语言的可变参数. 可变参数(Variable Parameters):参数数量可变的函数称之为可变参数函数,主要 ...

  4. 逆拓扑排序 Reward HDU - 2647

    Reward HDU - 2647 题意:每个人的起始金额是888,有些人觉得自己做的比另一个人好所以应该多得一些钱,问最少需要花多少钱,如果不能满足所有员工的要求,输出 -1 样例1: 2 1 1 ...

  5. Linux C++ 网络编程学习系列(5)——多路IO之epoll边沿触发

    多路IO之epoll边沿触发+非阻塞 源码地址:https://github.com/whuwzp/linuxc/tree/master/epoll_ET_LT_NOBLOCK_example 源码说 ...

  6. Kubectl patch命令使用

    kubectl patch 使用(patch)补丁修改.更新资源的字段. 支持JSON和YAML格式. 请参阅https://htmlpreview.github.io/?https://github ...

  7. vue 本地调试跨域---带cookies(axios)

    cookise跨域第二期之便捷优雅的本地调试(axios) 1.打开config/index.js,在proxyTable中添写如下代码: proxyTable: { '/agent': { //使用 ...

  8. three.js中让模型自动居中的代码如下:

    //load_Model为需要居中的3D模型 //原理是通过boundingBoxHelper 来计算模型的大小范围 var hex = 0xff0000; var MD_Length,MD_Widt ...

  9. stand up meeting 11/16/2015

    第一周,熟悉任务中~ 大致写下一天的工作: 冯晓云:熟悉bing接口,本意是调在线的必应词典API,参阅了大量C#调用API开发.net的工作,[约莫是因为有个窗口互动性更强,所以这样的工作更有趣,也 ...

  10. 无序map 记录一下

    unordered_map<int ,int >mp; unordered_map是基于hash表实现的,查找元素的复杂度可以达到o(1),查找n个元素,复杂度为o(n). map是基于红 ...