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