有这么一个题:
main()
{ int a=-521;
printf("%u",a);
}
运行的结果是65015。答案分析说-521在内存中保存为1111 1101 1111 0111,将这个二进制转化为无符号整数刚好就是65015。
我想问的是红字的部分怎么解释?请高手指点!!
----------------解决方案--------------------------------------------------------
呵呵,内存里都是0和1
%u是什么格式的呵呵不是二进制吧
----------------解决方案--------------------------------------------------------
%u是无符号 unsigned的输出格式..
这种题去看看数据类型就会懂的..不难理解!
----------------解决方案--------------------------------------------------------
我想知道的是-512和1111 1101 1111 0111是怎么互相转换的 是原码?补码?还是……
----------------解决方案--------------------------------------------------------
有这么一个题:
main()
{ int a=-521;
printf("%u",a);
}
运行的结果是65015。答案分析说-521在内存中保存为1111 1101 1111 0111,将这个二进制转化为无符号整数刚好就是65015。
我想问的是红字的部分怎么解释?请高手指点!!
<计算机基础>指出,对于16位即short int,
-521在内存中保存为1111 1101 1111 0111
这是“补码”表示法所决定的。最左边那个1
代表“负号”。记忆的方法是:
对于 short int 而言:
无符号数与带符号数在 0~32767 范围内表达方式是完全一样的。
然而,带符号数 -32768~-1的表达方式
竟然与无符号数 32768~65535 对应相同
于是发现下列公式:
负整数的补码=(该数+65536)的无符号表示
----------------解决方案--------------------------------------------------------
负数的话在内存中为第一位为1不变 然后其他位取反加1
1111 1101 1111 0111转化为十进制的话保持第一位不变然后先减1再其他位取反
1111 1101 1111 0110
1000 0010 0000 1001
=-(1+8+512)=-521
----------------解决方案--------------------------------------------------------
有这么一个题:
main()
{ int a=-521;
printf("%u",a);
}
运行的结果是65015。答案分析说-521在内存中保存为1111 1101 1111 0111,将这个二进制转化为无符号整数刚好就是65015。
我想问的是红字的部分怎么解释?请高手指点!!
int 类型整数在计算机内部存储为:最高位是符号位:0表示正,1表示负;
负数以补码形式存储
512的原码为:00 00 00 10 00 00 10 01
取反码为: 11 11 11 01 11 11 01 10
-512的补码为: 11 11 11 01 11 11 01 11
----------------解决方案--------------------------------------------------------
负数的话在内存中为第一位为1不变 然后其他位取反加1
1111 1101 1111 0111转化为十进制的话保持第一位不变然后先减1再其他位取反
1111 1101 1111 0110
1000 0010 0000 1001
=-(1+8+512)=-521
....10 0000 0000 是512
1000 是 8
1 是 1
相加就是521 诶..这个算法不错..我以前怎么没见到过..到现在我还用乘的呢~
那 10进制 变回2进制是不是 也这么变啊..?
求教..求教....
----------------解决方案--------------------------------------------------------
....不是
二进制的每三位为一个8进制数
二进制的每四位为一个16进制数
比如
00010010 = [0001] [0010] = 12H
00010010 = [000][010][010] = 022 (8进制)
----------------解决方案--------------------------------------------------------
8进制.和16进制 是3位 与 4位 我知道的.
那10进制呢..我现在 10进制变2进制 还用除呢.
看他上面的算法..好象也应该有个简单点的方法吧..
神..快教教我..
[此贴子已经被作者于2006-5-19 17:21:29编辑过]
----------------解决方案--------------------------------------------------------