编写一个方法,找出两个数字a
和b
中最大的那一个。不得使用if-else或其他比较运算符。
示例:
输入: a = 1, b = 2 输出: 2
我们可以提取
那么最后的结果就是
时间复杂度
class Solution:
def maximum(self, a: int, b: int) -> int:
k = (int(((a - b) & 0xFFFFFFFFFFFFFFFF) >> 63)) & 1
return a * (k ^ 1) + b * k
class Solution {
public int maximum(int a, int b) {
int k = (int) (((long) a - (long) b) >> 63) & 1;
return a * (k ^ 1) + b * k;
}
}
class Solution {
public:
int maximum(int a, int b) {
int k = ((static_cast<long long>(a) - static_cast<long long>(b)) >> 63) & 1;
return a * (k ^ 1) + b * k;
}
};
func maximum(a int, b int) int {
k := (a - b) >> 63 & 1
return a*(k^1) + b*k
}
function maximum(a: number, b: number): number {
const k: number = Number(((BigInt(a) - BigInt(b)) >> BigInt(63)) & BigInt(1));
return a * (k ^ 1) + b * k;
}