不用判断性语句,实现求两个整数中较大数的函数

转自:http://hi.baidu.com/todaygoodhujun/blog/item/b1be40105c94ebfcc3ce79d8.html

 

不用判断性语句,实现求两个整数中较大数的函数

要求:
不能使用 if、for、while、?:() 或其他任何带有判断性质的语句。不能使用内部实现有判断语句的函数。
写一个函数,max(int a, int b)返回a、b中较大的一个。不能用( abs(a+b) + abs(a-b) ) * 0.5,据说abs函数中也 使用了 if 语句。

=========http://ike.126.com
/**//**************************************************
Purpuse  : Evaluate the bigger one of two integers。
Author   : ALNG
Date     : 2003-03-11 
Original :
http://search.csdn.net/Expert/topic/1515/1515035.xml
**************************************************/
 
// 如果 i >= 0,返回0。否则返回1。在 max() 中被调用。
inline int signof(int i)
{
    return unsigned(i) >> (sizeof (int) * 8 - 1);
}
 
// 返回两个整型参数中数值较大的参数的值。
int max(int a, int b)
{
    int p[2];
    p[0] = a;
    p[1] = b;
 
    return p[signof(a - b)];
}


=====
a & b 比较大小有三种情况
a > b (这种情况下 a-b>0)
a < b (这种情况下 a-b<0)
a = b (不用说了,再说就废话连篇了)

计算机编码中(int类型的)
>0 = 0XXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX
<0 = 1XXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX

这样就有一个特点,右移31bit就会出现 0,1

如果为 0 则 a 大
如果为 1 则 b 大

=========

转载于:https://my.oschina.net/dake/blog/196859

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值