方法一:
直接用if语句判断
#include<iostream>
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<<max<<endl;
return 0;
}
方法二:
用求两数最大值公式:
max(a,b)=(a+b+abs(a+b))/2
#include<iostream>
#include<cmath>
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<<max<<endl;
return 0;
}
此外,求两数最小值公式:
min(a,b)=(a+b-abs(a-b))/2
方法三:
利用c++专门求两个数最大值最小值的函数,即algorithm头文件下的max()
#include<iostream>
#include<algorithm>
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<<max1<<endl;
return 0;
}
注意:①.有人说不用algorithm头文件也能运行出max(),min(),那只是针对个别编译器。
②.网上还有人说,做牛客网的在线编程题,有道题用到了max()函数,发现了一个小坑,比如max(a,0)时,若a是long long类型,就会报错,需要将0改成0ll。
附1:头文件cmath下的部分函数
绝对值:整数:abs() 浮点数fabs()
附2:头文件algorithm下的部分函数
最大最小操作
max() | 返回两个元素中值最大的元素 |
min() | 返回两个元素中值最小的元素 |
abs() | 返回元素绝对值 |
next_permutation | 返回给定范围中的元素组成的下一个按字典序的排列 |
修改内容操作
swap | 交换两个对象的值 |
reverse | 反转排序指定范围中的元素 |
fill | 将一个范围的元素赋值为给定值 |
排序操作
sort | 排序 |
查找操作
lower_bound | 返回指向范围中第一个值大于或等于给定值的元素的迭代器 |
upper_bound | 返回指向范围中第一个值大于给定值的元素的迭代器 |