免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: HappyWin
打印 上一主题 下一主题

不用判断语句,求两个数的最大值  关闭 [复制链接]

论坛徽章:
0
151 [报告]
发表于 2005-06-07 19:39 |只看该作者

不用判断语句,求两个数的最大值

原帖由 "wxycyel" 发表:
用了普通数据和能产生溢出的数据做了测试,在大概有十几组数据。如
-2000000000   2000000000
200000000     -2000000000
这样了数据。都通过了。


这不足以证明你的程序的正确性,你必须进行证明!

论坛徽章:
0
152 [报告]
发表于 2005-06-07 19:41 |只看该作者

不用判断语句,求两个数的最大值

原帖由 "win_hate" 发表:
#define MASK 0x7fffffff
int max (int x, int y)
{
   int z;

   z =  (x>;>;31) - (y>;>;31) + (((x&MASK) - (y&MASK))>;>;31);
   z= (z+1)*(z+2)*(3-2*z)/6;
   return z*x + (1-z)*y;
   
}


做一个简要的解释吧,一起分享

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
153 [报告]
发表于 2005-06-07 19:50 |只看该作者

不用判断语句,求两个数的最大值

原帖由 "win_hate" 发表:

#define MASK 0x7fffffff
int max (int x, int y)
{
   int z;

   z =  (x>;>;31) - (y>;>;31) + (((x&MASK) - (y&MASK))>;>;31);
   z= (z+1)*(z+2)*(3-2*z)/6;
   return z*x + (1-z)*y;
   
}

当x>;0,y>;0时,x>;>;31=0,y>;>;31=0,x&MASK =0,y&MASK=0,所以第一个z=0
第二个z = 1*2*3/6 = 1
所以max=x
可以用2、3试一下的说
sorry!我还没看懂算法。。。

论坛徽章:
0
154 [报告]
发表于 2005-06-07 20:02 |只看该作者

不用判断语句,求两个数的最大值

真受不了,没事瞎折腾。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
155 [报告]
发表于 2005-06-07 20:40 |只看该作者

不用判断语句,求两个数的最大值

wxycyel是个高手,他的程序还是基于x-y的,把x-y、x、y三个的最高位组合在一起进行判断,所以用了一个2^3=8的数组以确定最后的值
有道理!
mm_009 该用户已被删除
156 [报告]
发表于 2005-06-07 20:41 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
157 [报告]
发表于 2005-06-07 20:49 |只看该作者

不用判断语句,求两个数的最大值

原帖由 "yuxh" 发表:

当x>;0,y>;0时,x>;>;31=0,y>;>;31=0,x&MASK =0,y&MASK=0,所以第一个z=0
第二个z = 1*2*3/6 = 1
所以max=x
可以用2、3试一下的说
sorry!我还没看懂算法。。。


x&MASK =0,y&MASK=0,你弄糊涂了吧

他这个算法不错,用((x&mask) - (y&mask)) >;>; 31来决定同符号的两数的大小比较,然后再加上x,y的符号信息,就能完全判断了。其他的代码我还没弄懂,望作者加以解释。

这个算法应该算是以上算法中最简单的了!

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
158 [报告]
发表于 2005-06-07 20:54 |只看该作者

不用判断语句,求两个数的最大值

[quote]原帖由 "zleil"]牧耍?/quote 发表:

sorry!我没看清()!

论坛徽章:
29
戌狗
日期:2013-11-14 09:53:052016科比退役纪念章
日期:2016-07-12 18:29:4415-16赛季CBA联赛之新疆
日期:2016-11-07 13:15:0015-16赛季CBA联赛之辽宁
日期:2017-01-18 10:23:5115-16赛季CBA联赛之吉林
日期:2017-05-02 14:02:2319周年集字徽章-年
日期:2020-01-15 13:50:582016科比退役纪念章
日期:2021-06-03 14:15:3115-16赛季CBA联赛之山东
日期:2021-06-21 17:30:5615-16赛季CBA联赛之江苏
日期:2021-06-22 16:42:2015-16赛季CBA联赛之深圳
日期:2021-12-21 15:54:0215-16赛季CBA联赛之佛山
日期:2022-04-08 09:43:5715-16赛季CBA联赛之广东
日期:2022-06-29 19:59:19
159 [报告]
发表于 2005-06-07 20:56 |只看该作者

不用判断语句,求两个数的最大值

原帖由 "zleil" 发表:

具体没看完,
问一下:int z=x-y;语句,你考虑溢出了吗?



还有,建议大家贴出程序之前,把自己的思路做一个简要的描述!

论坛徽章:
0
160 [报告]
发表于 2005-06-07 21:06 |只看该作者

不用判断语句,求两个数的最大值

根据win_hate的想法,再来一段
#define MASK 0x7fffffff
int max (int x, int y)
{
    int sx;    // x的符号
    int sy;    // y的符号
    int s;      // x,y在去掉符号位后,如果x大,则s=1;否则为0
    int is_x;  // 如果最大值是x,则为1,否则为0
    sx = x >;>; 31;
    sy = y >;>; 31;
    s = ((x&MASK) - (x&MASK)) >;>; 31;
    is_x = ( (!(sx^sy)) & s ) | ( (sx^sy) & sy );
    return is_x*x + (!is_x)*y;
}
真值表:
sx  sy  s     is_x
0   1    *      1
0   0    s      s
1   1    s      s
1   0    *      0
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP