当前位置: 代码迷 >> C语言 >> [求助]关于整形int在内存中的是如何保存的?
  详细解决方案

[求助]关于整形int在内存中的是如何保存的?

热度:164   发布时间:2006-05-19 12:39:00.0
[求助]关于整形int在内存中的是如何保存的?

有这么一个题:
main()
{ int a=-521;
printf("%u",a);
}
运行的结果是65015。答案分析说-521在内存中保存为1111 1101 1111 0111,将这个二进制转化为无符号整数刚好就是65015。
我想问的是红字的部分怎么解释?请高手指点!!

I need your help!!!
搜索更多相关的解决方案: 内存  int  整形  保存  

----------------解决方案--------------------------------------------------------
呵呵,内存里都是0和1
%u是什么格式的呵呵不是二进制吧

----------------解决方案--------------------------------------------------------
%u是无符号 unsigned的输出格式..

这种题去看看数据类型就会懂的..不难理解!

----------------解决方案--------------------------------------------------------

我想知道的是-5121111 1101 1111 0111是怎么互相转换的 是原码?补码?还是……


----------------解决方案--------------------------------------------------------
回复:(zgwxwn)[求助]关于整形int在内存中的是如何保...
以下是引用zgwxwn在2006-5-19 12:39:00的发言:

有这么一个题:
main()
{ int a=-521;
printf("%u",a);
}
运行的结果是65015。答案分析说-521在内存中保存为1111 1101 1111 0111,将这个二进制转化为无符号整数刚好就是65015。
我想问的是红字的部分怎么解释?请高手指点!!

I need your help!!!

<计算机基础>指出,对于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
----------------解决方案--------------------------------------------------------
以下是引用zgwxwn在2006-5-19 12:39:00的发言:

有这么一个题:
main()
{ int a=-521;
printf("%u",a);
}
运行的结果是65015。答案分析说-521在内存中保存为1111 1101 1111 0111,将这个二进制转化为无符号整数刚好就是65015。
我想问的是红字的部分怎么解释?请高手指点!!

I need your help!!!

int 类型整数在计算机内部存储为:最高位是符号位:0表示正,1表示负;
负数以补码形式存储

521=512+8+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

----------------解决方案--------------------------------------------------------
以下是引用工藤♀新一在2006-5-19 13:45:00的发言:
负数的话在内存中为第一位为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编辑过]


----------------解决方案--------------------------------------------------------
  相关解决方案