【干货】小白最容易放弃的二进制详解!

二进制,八进制,十六进制一直困扰着很多小伙伴,今天老九君就给小伙伴们讲解一下进制转化。

在计算机的世界里,只有0和1,也就是二进制。

我们如何把一个十进制的数转成二进制或者其他进制,其实还是很简单的,看下面这张图

十进制转二进制

十进制的123转成二进制就是1111011,转成几进制都是一个道理。

一、二进制

1.1 二进制是计算机采用的表示数字的方式, 每个数位上只有0和1;

1.2 任何整数一定可以采用二进制的方式表示, 小数的二进制这里不多说;

1.3 字节内部采用二进制方式记录数字, 一个字节分成八段, 每个分段有一个编号, 最右边分段编号是0, 向左逐渐递增

1.4 相邻分段之间有2倍关系, 某个分段的数字相当于2的编号次方, 如图:

二进制转十进制:

把每个数位单独转换后把所有的转换结果求和

例:01001110 = 2^6 + 2^3 + 2^2 + 2^1 = 64 + 8 + 4 + 2 = 78

十进制转二进制:

方法一:(不适用于处理大数字)先把十进制数字拆分成多个2的整数次方之和, 然后对每个结果单独转换, 最后其他数位补0。

59 = 32 + 16 + 8 + 2 + 1 = 2^5 + 2^4 + 2^3 + 2^1 + 2^0 = 00111011

方法二:除2取余, 逆序余数;

上述两种方法算出来的是二进制原码

计算机字节里采用二进制补码记录数字

所有非负数整数, 补码和原码一样

二、八进制

2.1 把二进制表示方式的所有数位从右向左每三个数位分成一组, 每组用一个0到7之间的数字代替可得到八进制表示方式

2.2 每三个数位可以采用421方法把二进制转化成八进制

2.3 可以在程序中使用八进制表示数字, 为了避免与十进制混淆, 需要在八进制前面加0(零)

2.4 %o可以作为八进制数的占位符

结果:

152 106

152 152

三、十六进制

3.1 所有数位从右向左每四个数位分成一组, 每组用一个字母替换就得到对应的十六进制表示方式, 先把每组转换成十进制, 转换结果如果在0到9之间则用阿拉伯数字字符替换, 否则用‘a’到'f'这六个英文字母替换

3.2 每四个数位可以采用8421方法把二进制转化成十六进制

3.2 可以在程序中使用十六进制表示数字, 但是必须以0x做开头

3.3 %x %X 可以作为十六进制数的占位符(%x输出a-f, %X输出A-F)

结果:

0xab 0XAB

练习: 十进制转二进制

四、负数的二进制

4.1 先计算出相反非负数的二进制

4.2 把第一步的计算结果每个数位变成相反内容, 然后再加一

求:-5的二进制:

5: 0000 0101

取反: 1111 1010 + 1

-5: 1111 1011

4.3 上述方法算出来的是二进制补码, 可以直接记录在字节中

4.4 有符号的二进制补码中最左边的数位叫做符号位, 符号位是0表示正, 1表示负, 且符号位不能等同与正负号

4.5 当把一个占地大的整数类型数据赋值给占地小的整数类型存储区时只会保留部分二进制数据, 因此导致十进制表示方式发生变化。

4.6 当把一个占地小的整数赋值给占地大的整数类型存储区时要扩充二进制数位, 在有符号位的情况下扩充出来的二进制里全是符号位的数值, 无符号数据填充0;

结果:

ch = 44

num = 44

分析:300是整数占四个字节, 用二进制表示如下(ps: 只保留最右边的)

00000000 00000000 00000001 00101100

练习:计算下面的结果(结果在下方)

结果:

ch = -56

num = -56

小伙伴们掌握了吗?一定要多多的练习哦~这样二进制的题目那是手到擒来!

问:下面结构体的定义语句中,错误的是( )。

A) struct ord {int x;int y;int z;} struct ord a;

B) struct ord {int x;int y;int z;}; struct ord a;

C) struct ord {int x;int y;int z;} a;

D) struct {int x;int y;int z;} a;

原文发布于微信公众号 - 老九学堂(xuetang9)

原文发表时间:2017-11-09

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏web前端教室

javascript 红皮高程(17)-- 按位异或(XOR)

不吐槽了,继续研究JS,今天是按位异或这个操作符,它用符号(^)表示,它也是有二个操作数,这二个数当然也是十进制转成二进制之后的数。 它的规则就是,二个数的数值...

1726
来自专栏增长技术

位运算

812
来自专栏mathor

波兰表达式

764
来自专栏技术博文

PHP函数篇详解十进制、二进制、八进制和十六进制转换函数说明

一,十进制(decimal system)转换函数说明  1,十进制转二进制 decbin() 函数,如下实例  echo decbin(12); //输出 ...

3136
来自专栏C语言及其他语言

【每日一题】问题 1074: 数字整除

定理:把一个至少两位的正整数的个位数字去掉,再从余下的数中减去个位数的5倍。当且仅当差是17的倍数时,原数也是17的倍数 。

1182
来自专栏陈树义

BitMap 算法

什么是 BigMap 算法 所谓 BitMap 就是用一个 bit 位来标记某个元素对应的 value,而 key 即是这个元素。由于采用bit为单位来存储数据...

3046
来自专栏Java爬坑系列

【JAVA零基础入门系列】Day9 Java中的那个大数值

  什么是大数值?用脚趾头想也知道,当然是“大”的数值(233)。Java中有两个用于表示大数值的类,BigInteger和BigDecimal,那到底能表示多...

17310
来自专栏青枫的专栏

c语言基础学习03_数据类型与运算符

============================================================================= 涉及...

491
来自专栏编程坑太多

javascript各进制前缀 及 转换

1414
来自专栏desperate633

LintCode 尾部的零题目分析代码

例子:(1000的阶乘末尾0的个数)**** 1000 / 5 + 1000 / 25 + 1000 / ...

712

扫码关注云+社区