《算法笔记》读书记录DAY_22

本文详细介绍了C++ STL中algorithm头文件的重要功能,包括max()、min()、abs()用于比较和获取绝对值,swap()用于交换数值,reverse()用于反转序列,next_permutation()生成序列的下一个全排列,以及fill()用于填充数组或容器的指定区域。这些函数基于迭代器,极大地增强了C++的效率和灵活性。

CHAPTER_6  C++STL相关

 

 

 6.9头文件algorithm

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

//输出结果:2 1

(3)reverse()

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

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

//输出结果:2 1 3

string s="abcde";
reverse(s.begin(),s.end());
cout<<s;

//输出结果:edcba

(4)next_permutation()

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

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

//输出结果:
            123
            132
            213
            231
            312
            321     

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

(5)fill()

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

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值