#include
#define max(a,b) ((((long int)((a)-(b)))&0x80000000)?b:a)
void main()
{
int t,a,b;
cout<<"output a,b"< cin>>a,b;
t=max(a,b);
cout<<t<<endl;
}
为什么运行结果老是a的值?
((((long int)((a)-(b)))&0x80000000)?b:a) / 这是通过判断符号位进行大小判断 /
运行下看看吧
1-3 = -2;
我开始以为可能和64bit 32bit有关,
64位机器(long int)-2的计算机二进制对应十六进制表示是0xfffffffffffffffe
32位机器(long int)-2的计算机二进制对应十六进制表示是0xfffffffe
两者和0x80000000相与运行的效果都是相同的,结果为1,所以最大值为b,即是3
这两者都是没有关系的 算出来的结果都是正确的。
我对你的源码略做修改,因为你的源码我运行的比较乱。
#include
#define max(a,b) ((((long int)((a)-(b)))&0x80000000)?b:a)
using namespace std;
int main()
{
int t,a,b;
cout << "output a,b" << endl;
cin >>a >> b;
t = max(a, b);
cout<<t<<endl;
return 0;
}
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。