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下的部分函数 绝对值:整数:abs() 浮点数fabs() 附2:头文件algorithm下的部分函数 最大最小操作 max() 返回两个元素中值最大的元素 min() 返回两个元素中值最小的元素 abs() 返回元素绝对值 next_permutation 返回给定范围中的元素组成的下一个按字典序的排列 修改内容操作 swap 交换两个对象的值 reverse 反转排序指定范围中的元素 fill 将一个范围的元素赋值为给定值 排序操作 sort 排序 查找操作 lower_bound 返回指向范围中第一个值大于或等于给定值的元素的迭代器 upper_bound 返回指向范围中第一个值大于给定值的元素的迭代器
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
