您的位置:首页 > 职场人生

面试题:两个整数不使用比较运算符和API得到更大的那个值

2014-11-19 21:59 218 查看
两个整型数,不准用if 、switch 、?:等判断语句求出两者大值,不能使用api



我这里2个实现方法如下:

[java] view
plaincopy

/**

* 不用比较运算符得到2个数字的更大值。

*

* @author J***A世纪网(java2000.net)

*/

public class Test3 {

public static void main(String[] args) {

int[] as = { 44, 55, 44, 4, 40, -44, -55 };

int[] bs = { 55, 44, 4, 44, 40, -55, -44 };

for (int i = 0; i < as.length; i++) {

System.out.println(max2(as[i], bs[i]));

System.out.println(max3(as[i], bs[i]));

System.out.println();

}

}

/**

* 使用移位操作

*

* @param a

* @param b

* @return

*/

public static int max2(int a, int b) {

int[] nums = { a, b };

return nums[(a - b) >>> 31];

}

/**

* 使用乘法操作

*

* @param a

* @param b

* @return

*/

public static int max3(int x, int y) {

return x-(x-y)*((x-y)>>>31);

}

}



重点就是那个>>> 的移位操作。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐