一、C语言中的正码,反码,和补码作何解释(名词解释)

补码,是在计算机内部,正负数的存放格式。

在计算机内部,并没有“正码”、“反码”。

C 语言是高级语言。

用高级语言编程,是不用关心计算机内部的事的。

如果非要涉及计算机内部的细节,那就不是高级语言了。

很多教材书籍的作者,都没有弄明白:什么是高级语言。

计算机内部的码,有很多种了,要是讨论起来,C 语言就学不完了。

二、c补码的代码写法

c语言补码的表示方法是:正数的补码就是其本身,负数的补码是在其原码的基础上,符号位不变,其余各位取反,最后+1 (即在反码的基础上+1)。

[+1] = [00000001](原码) = [00000001](反码) = [00000001](补码) [-1] = [10000001](原码) = [11111110](反码) = [11111111](补码) 对于负数,补码表示方式也是人脑无法直观看出其数值的。通常也需要转换成原码在计算其数值。 一、原码 求原码:X≥0,则符号位为0,其余照抄; X≤0,则符号位为1,其余照抄。 【例1】X=+1001001 [X]原 = 01001001 【例2】X=-1001001 [X]原 = 11001001 二、反码 求反码:若X≥0,符号位为0,其余照抄; 若X≤0,符号位为1,其余按位取反。 【例3】X=+1001001 [X]反 = 01001001 【例4】X=-1001001 [X]反 = 10110110 三、补码 求补码:若X≥0,符号位为0,其余照抄; 若X≤0,符号位为1,其余取反后,最低位加1。 【例5】X=+1001001 [X]补 = 01001001 【例6】X=-1001001 [X]补 = 10110111

三、c语言中补码怎么算的

首先建议楼主去恶补一下“原码”、“反码”以及“补码”的相关知识。

以下我就先来分析一下(假设你已经了解了这些知识):

首先我们以无符号的视点来看待题目中的数据:

n = 0x7FFF

m = 0x8000

可知对于n来说,他的二进制模式为:0111 1111 1111 1111

对于m来说,他的二进制模式为: 1000 0000 0000 0000

可以看到,最高位符号位n为0,而m为1

所以用带符号数的视角来看待m、n的这串二进制数据,我们知道n符号位(最高位)为零,所以n是正数,而m符号位为1,因而是负数。

对于补码,正数好计算,就是他的值,也就是0111 1111 1111 1111 = 0x7FFF = 32767

对于负数m,为了知道他的值我们可以这么干:

假设m的绝对值|m| = x,则我们对m就可以得到x

m = 1000 0000 0000 0000

取反:

~m = 0111 1111 1111 1111

加1

~m + 1 = 1000 0000 0000 0000

(这道题数据比较特殊,所以你看到m和~m+1结果貌似一样,事实上你可以列举其他值算算,一般这两个位模式是不同的)

可知x = 32768

则可知m = -x = -32768

以上

四、正数的补码

正数的原码,反码,补码 一样,就是原码的样子。

例如: 原码 0x8B; 它的 反码是 0x8B; 补码 也是 0x8B。

---

记牢:负数的 补码 等于 (不改变符号位)它原码的反码 加 1。

正数的 补码 等于 它自己。