C++ 求最大值最小值宝藏方法

方法一:

直接用if语句判断

#include

using namespace std;

int main()

{

int a,b,c;

cin>>a>>b>>c;

int max;

if(a>b&&a>c)

max=a;

if(c>a&&c>b)

max=c;

if(b>a&&b>c)

max=b;

cout<

return 0;

}

方法二:

用求两数最大值公式:

max(a,b)=(a+b+abs(a+b))/2

#include

#include

using namespace std;

int main()

{

int a,b,c,max;

cin>>a>>b>>c;

max=(a+b+abs(a-b))/2;

max=(max+c+abs(max-c))/2;

cout<

return 0;

}

此外,求两数最小值公式: min(a,b)=(a+b-abs(a-b))/2

方法三:

利用c++专门求两个数最大值最小值的函数,即algorithm头文件下的max()

#include

#include

using namespace std;

int main()

{

int a,b,c;

int max1=0;

cin>>a>>b>>c;

max1=max(a,b);//调用库函数max

max1=max(max1,c);

cout<

return 0;

}

注意:

①.有人说不用algorithm头文件也能运行出max(),min(),那只是针对个别编译器。

②.网上还有人说,做牛客网的在线编程题,有道题用到了max()函数,发现了一个小坑,比如max(a,0)时,若a是long long类型,就会报错,需要将0改成0ll。

附1:头文件cmath下的部分函数

C++ 求最大值最小值宝藏方法_第1张图片

绝对值:整数:abs() 浮点数fabs()

附2:头文件algorithm下的部分函数

最大最小操作

max() 返回两个元素中值最大的元素

min() 返回两个元素中值最小的元素

abs() 返回元素绝对值

next_permutation 返回给定范围中的元素组成的下一个按字典序的排列

修改内容操作

swap 交换两个对象的值

reverse 反转排序指定范围中的元素

fill 将一个范围的元素赋值为给定值

排序操作

sort 排序

查找操作

lower_bound 返回指向范围中第一个值大于或等于给定值的元素的迭代器

upper_bound 返回指向范围中第一个值大于给定值的元素的迭代器

你可能感兴趣的:(C++,c++,算法)