STL c++

来源:互联网 发布:如何正确看待体检数据 编辑:程序博客网 时间:2024/06/02 03:16

sort函数

需要添加头文件  

#include<algorithm> 

using namespace std;

功能:

排序,整数数组,字符串,结构体排序,函数默认从小到大排序,其它排序需要添加cmp函数;

运用:

sort(a,a+n);默认将数组a从小到大排序;

int cmp(int a,int b)

{

 return a>b;

}

sort(a,a+n,cmp);

将数组a从大到小排序,n代表数组a有n个元素;

结构体:

int cmp(st a,st b)//a和b都是结构体类型

{

     return a.x<b.x;

}//以结构体中某一个元素为基础排序。

sort(a,a+n,cmp);

lower_bound函数:

添加头文件:

#incldue<algorithm>

using namespace std;

功能:

查找数组中第一个大于等于x的位置;需要排序,该函数从数组的第一个开始查找,直到第一个大于等于x的位置终止

运用:

int y=lower_bound(a,a+n,x)-a;

函数返回的是数组中x的指针,减去第一个元素的指针,即为x的位置。

需要判断a[y]是否等于x,等于时间说明数组中有x这个数,如果不相等就说明数组a中没有x。

unique 函数

作用:

去重操作,去掉相邻元素的重复操作。不过不是真正意义上的删除,只是把重复的部分移动到数组的最后,之后函数返回第一个重复地方的指针。

例如:

1,2,2,3,3,5;

函数运用之后数组应为:1,2,3,5,2,3;

函数返回值为当前数组中5的位置。

添加头文件

#include<iostream.h>

运用:

int x = unique(a,a+10) - a;


原创粉丝点击