码迷,mamicode.com
首页 > 编程语言 > 详细

【C/C++】获取整数的二进制形式字符串

时间:2015-03-30 09:37:56      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:

思路


使用循环使整数左移i位,并取最高位,如果当前最高位为1则值为‘1‘,否则为‘0‘。这样拼接出一个字符串。


注意:计算机中存储的是数字的补码。


关于正、负数的原码、反码、补码。

正数:原码、反码、补码都一样。 
负数:反码(除了最高位,其它位取反)补码(反码+1) 


为什么要存储补码,而不是原码?

为了统一运算方法。使用补码对有符号整数进行加、减不需要关心符号位。 
例如:1 + (-2) = -1 
-2的原码 
1000 0000 0000 0000 0000 0000 0000 0010 
-2的反码 
1111 1111 1111 1111 1111 1111 1111 1101 
-2的补码 
1111 1111 1111 1111 1111 1111 1111 1110 

计算过程: 
    0000 0000 0000 0000 0000 0000 0000 0001 
+ 1111 1111 1111 1111 1111 1111 1111 1110 
= 1111 1111 1111 1111 1111 1111 1111 1111 
-1的补码:1111 1111 1111 1111 1111 1111 1111 1111 


使用补码把有符号整数的计算简化成一步,大大提高了效率。 
如果使用原码:1.判断数字的符号位。2.取被加/减数的绝对值 3.加上/减去绝对值 

代码



技术分享

【C/C++】获取整数的二进制形式字符串

标签:

原文地址:http://blog.csdn.net/linchaolong/article/details/44729039

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!