实现一个方法求两个数中的较大值,但不可以用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;
}