栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

《算法笔记》读书记录DAY

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

《算法笔记》读书记录DAY

CHAPTER_6  C++STL相关

 

 

 6.9头文件algorithm

algorithm是C++的标准模版库(STL)中最重要的头文件之一,提供了大量基于迭代器的非成员模板函数。使用时需要引入头文件#include ,并且下方要加一行"using namespace std;"。

(1)max()、min()、abs()

 max(x,y)和min(x,y)分别返回x和y中的最大值和最小值,且参数必须是两个(可以是浮点数)。如果想得到三个数x、y、z的最大值,可以用max(x,max(y,z))这种方法,三个数最小值也是同理。

 abs(x)返回x的绝对值,x必须是整数。浮点数的绝对值请用math头文件下的fabs函数。

(2)swap() 

 swap(x,y)用来交换两个数的值。例如:

int x=1,y=2;
swap(x,y);
cout< 

(3)reverse()

reverse(it1,it2)可以将[it1,it2)区间内的元素倒置(it1和it2可以是指针或者迭代器)。例如:

a[3]={1,2,3};
reverse(a,a+2);
cout<

(4)next_permutation()

 next_permutation()给出一个序列在全排列中的下一个序列。例如:

int a[3]={1,2,3};
//a[0]~a[2]间的序列求解全排列
do{
    cout<

上述代码中,使用循环是因为next_permutation在到达全排列最后一个时会返回false。

(5)fill()

 fill()可以把数组或容器中某区间赋为相同的值。和memset不同,这里的赋值可以是数组类型对应   范围中的任意值。例如:

int a[5]={1,2,3,4,5};
fill(a,a+4,10);                //将从a开始4个元素赋值为10

vector v(3,0);            //定义vector并初始化为3个0
fill(v.begin(),v.begin()+3,5); //将v的3个元素赋值为5

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/311592.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号