c语言原码 补码 反码,C语言 原码--反码--补码

//原码,反码,补码

#include

#include

//数值的表示方法——原码、反码和补码

//原码:最高位为符号位,其余各位为数值本身的绝对值

//反码:

//正数:反码与原码相同

//负数:符号位为1,其余位对原码取反

//补码:

//正数:原码、反码、补码相同

//负数:最高位为1,其余位为原码取反,再对整个数加1

//

//

//在计算机系统中,数值一律用补码来表示(存储)。

//主要原因:使用补码,可以将符号位和其它位统一处理;同时,减法也可按加法来处理。

//另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。

//采用原码表示法简单易懂,但它的最大缺点是加法运算复杂。

//这是因为,当两数相加时,如果是同号则数值相加;如果是异号,则要进行减法。

//而在进行减法时还要比较绝对值的大小,然后大数减去小数,最后还要给结果选择符号。

//为了解决这些矛盾,人们找到了补码表示法。机器数的补码可由原码得到。

//如果机器数是正数,则该机器数的补码与原码一样;

//如果机器数是负数,则该机器数的补码是对它的原码(除符号位外)各位取反,并在未位加1而得到的。

void main(){

int x = -;

//int是四字节,1字节8位,所以-1有32位,最高位符号位

//原码:1000 0000 0000 0000 0000 0000 0000 0001

//反码:1111 1111 1111 1111 1111 1111 1111 1110

//补码:1111 1111 1111 1111 1111 1111 1111 1111

int y = ;//正数原码,反码,补码全部相同

//int是四字节,1字节8位,所以-1有32位,最高位符号位

//原码:0000 0000 0000 0000 0000 0000 0000 0011

//反码:0000 0000 0000 0000 0000 0000 0000 0011

//补码:0000 0000 0000 0000 0000 0000 0000 0011

//求x+y?

//在计算机系统中,数值一律用补码来存储,

//x的补码:1111 1111 1111 1111 1111 1111 1111 1111

//y的补码:0000 0000 0000 0000 0000 0000 0000 0011

//x+y :0000 0000 0000 0000 0000 0000 0000 0010 -----如果最高位(符号位)有进位,则进位被舍弃。

//因此x+y=2

printf("%d\n", x);

//总结:由补码获取源码,直接将补码减1,然后除去符号位全部取反

system("pause");

}

C语言原码反码补码与位运算.

目录:     一.机器数和真值     二.原码,反码和补码的基础概念     三.为什么要使用原码,反码和补码     四.原码,补码,反码再深入     五.数据溢出测试     六.位运算 ...

「C语言」原码反码补码与位运算

尽管能查到各种文献,亲自归纳出自己的体系还是更能加深对该知识的理解.     本篇文章便是在结合百度百科有关原码.反码.补码和位运算的介绍并深度借鉴了张子秋和Liquor相关文章后整理而出.   目录 ...

C语言学习笔记之原码反码补码

原码:就是我们自己看的,以及机器输出给我们看的 补码:机器永远是以补码的形式将数据保存在计算机中 正数: 原码=反码=补码 负数: 反码:原码的符号位不变,其他位取反 ,1变0   0变1 补码:机器 ...

JAVA:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题(5)

一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...

原码 & 反码 & 补码 & 详解

本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希 ...

Java学习第五篇:二进制(原码 反码 补码),位运算,移位运算,约瑟夫问题

一.二进制,位运算,移位运算 1.二进制 对于原码, 反码, 补码而言, 需要注意以下几点: (1).Java中没有无符号数, 换言之, Java中的数都是有符号的; (2).二进制的最高位是符号位, ...

python之计算机硬件基本认知_数据单位_进制间转换_数的原码反码补码

一:计算机硬件基本认知 cpu:   中央处理器.   相当于人的大脑.运算中心,控制中心. 内存:  临时存储数据. 优点:读取速度快,缺点:容量小,造价高,断电即消失. 硬盘:  长期存储数据. ...

C 标识符, 数据存储形式(原码,反码,补码)

一.  标识符 第一个字母必须是英文字母或下划线 二. 数据存储形式(补码存储) 最高位是符号位 ---- 0表示整数 ; 1 表示负数 1. 正数:原码 = 反码 = 补码 例子 : (10) 原码 ...

java基础知识-原码,反码,补码

1.正数:原码,反码,补码:都一样. 2.负数:和正数的储存方式不同,负数都是以补码形式存储的. <1>负数的补码 把负数的原码除了符号位取反后再+1. <2>负数的原码 把对 ...

随机推荐

Yii2使用教程

安装 中文文档:http://www.yiichina.com/doc/guide/2.0/start-installation 1,安装 这里我直接下载归档文件,压缩包安装了.composer各种麻 ...

带权图的最短路径算法&lpar;Dijkstra&rpar;实现

一,介绍 本文实现带权图的最短路径算法.给定图中一个顶点,求解该顶点到图中所有其他顶点的最短路径 以及 最短路径的长度.在决定写这篇文章之前,在网上找了很多关于Dijkstra算法实现,但大部分是不带 ...

c&num;新语法学习笔记

1.匿名类 匿名类编译之后会生成一个具体的泛型类,匿名类的属性是只读的.在临时数据传递时非常方便(linq查询).匿名类中不能有方法.数据传输(json),数据查询(linq) }; 2.匿名方法匿名 ...

Javascript DOM基础(一)概念

Dom基础概念:

...
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值