搜索
编程论坛
→
开发语言
→
C++论坛
→
『 C++教室 』
→ 比较两个数的大小题
标题:
比较两个数的大小题
只看楼主
forclwy
等 级:
业余侠客
帖 子:167
专家分:255
注 册:2008-10-21
结帖率:
100%
楼主
已结贴
√
问题点数:20 回复次数:1
比较两个数的大小题
谁能帮我解释下:
#define MAX(a,b) ((long)(a-b)&0x80000000 ? b:a)
0x80000000这块是什么??
谢啦
2009-08-31 20:17
tsy1984
等 级:
新手上路
帖 子:1
专家分:0
注 册:2009-10-4
第
2
楼
得分:0
0x表示十六进制数,0x8的二进制表示为1000
32位系统的long为4字节,0x80000000为首位为1,其余位为0的四字节长的二进制数。
对于有符号数,首位是符号为,1表示负,0表示正。“&”为按位与操作。
该宏即是将a-b的结果与0x80000000按位与,目的是判断a-b的最高位是否为1,如果(a-b)&0x80000000的结果为非零,则说明a-b的最高位为1,即a-b为负,即a<b。
反之则说明a-b的最高位为0,即a-b为非负,即a>=b。
2009-10-04 16:45
2
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-284320-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 1.097223 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved