实现一个方法求两个数中的较大值,但不可以用if-else或其他比较操作符。
思路:
给定两个数a和b,最直观的思路就是看a - b和0的关系,但不允许用比较操作符。可以注意到,当a > b的时候,a - b的结果最高位为0,否则为1。我们另k为a - b的最高位的值,那么最大值就等于a - k*(a - b)。
#include <iostream>
using namespace std;
int Max(int a, int b)
{
int c = a - b;
int k = (c >> 31) & 1;
return a - k * (a - b);
}
int main()
{
int a, b;
while (cin >> a)
{
cin >> b;
cout << Max(a, b) << endl;
}
return 0;
}

本文介绍了一种不使用if-else或其他比较操作符来确定两个整数中较大值的方法。通过位运算和算术运算实现了这一目标,提供了一个具体的C++代码示例。
43

被折叠的 条评论
为什么被折叠?



