博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
感悟C语言的特点
阅读量:5041 次
发布时间:2019-06-12

本文共 1319 字,大约阅读时间需要 4 分钟。

计数的学问——进制

  • 十进制

上学之初,我们就学过1、2、3、4、5、6、7、8、9的数字,后来提高要求还学习了“0眨眼。这十个数字让我们可以方便地进行日常的计数:如我们家有3口人;我们学校有1857人。小学老师教过我,数字的世界里有一位数,也有两位数……当然1857就是四位数!从右往左,依次就有了“个”位、“十”位、“百”位、“千”位……,因此1857就像是如下排列:

千位 百位 十位 个位
1 8 5 7
老师还特意强调过:所谓“十进制”,就是“逢十进一”!所以当你的“个位”从0增加到9……如果再增加1,那就需要在“十位”增加数字1,个位表示0,组合成一个两位数10。因此,我们可以像下面图示这样来“深入”地理解1857这个数字!其中每个“位”中的数字只能从0-9变化,即数字小于“10”这个基数。

(1 * 1000) + (8 * 100) + (5 * 10) + (7 * 1) = 1000 + 800 + 50 + 7 = 6357

(1 * 103) + (8 * 102) + (5 * 101) + (7 * 100) = 1000 + 800 + 50 + 7 = 6357

千位 百位 十位 个位
103 102 101 100
1 8 5 7
可见,十进制不过是以10为基数的一种计数系统。
  • 二进制

如果是以2为基数来计数呢?我们知道,小于基数2的数字只有两个:0和1。因此,各个“位”中的数字不是0就是1!0或者1表示了两种可能的状态:如“开”或“关”,就像电灯的“亮”或“灭”——电子管或晶体管可以有效地提供实现这种方法的物理规则。那么,如下的二进制数字“1011”表示的数,相当于我们熟知的十进制数字是什么呢?我们不妨进行以上步骤的逆向方法:

23 22 21 20
1 0 1 1

(1 * 23) + (0 * 22) + (1 * 21) + (1 * 20) = 8 + 0 + 2 + 1 = 11

一般来说,计算机中以8个位(bit)联合起来表示常用的一些数字,其中每一格都在物理上实现了0或者1的可能机制。你可以相像这是8个灯泡形成的一组表示某种特定意义的序列。

0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1

 

 

128 64 32 16 8 4 2 1
0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1
如果我们要表示94,依据上表,我们发现可以这样实现:128对应的格子我们赋予0,显然94小于128;64对应的格子我们赋予1;32对应的格子赋予0,不然64+32=96,大于94了;后面的格子我们如果能凑上30,就能刚好表示94了,因为16+8+4+2=30,所以可以如下表示:
128 64 32 16 8 4 2 1
0 1 0 1 1 1 1 0
二进制“0101 1110”表示的就是十进制数“94
”。
  • 其他进制——八进制,十六进制

明白了上述表示方法的实质,相信你也能十分容易地领悟到其他进制的换算方法了。

转载于:https://www.cnblogs.com/shudibo/archive/2013/01/03/2842633.html

你可能感兴趣的文章
Java8 Lambda表达应用 -- 单线程游戏server+异步数据库操作
查看>>
次序+“选择不重复的记录”(3)——最大记录
查看>>
Codeforces 450 C. Jzzhu and Chocolate
查看>>
[Unity3D]Unity3D游戏开发MatchTarget的作用攀登效果实现
查看>>
ACdream 1115 Salmon And Cat (找规律&&打表)
查看>>
JSON、JSONP、Ajax的区别
查看>>
AngularJS学习篇(一)
查看>>
【转载】 IP实时传输协议RTP/RTCP详解
查看>>
关于Xshell无法连接centos6.4的问题
查看>>
Linux系统的数据写入机制--延迟写入
查看>>
css3动画——基本准则
查看>>
javaweb常识
查看>>
Java注解
查看>>
时间>金钱
查看>>
元数据元素
查看>>
Visual Studio Code 构建C/C++开发环境
查看>>
web自己主动保存表单
查看>>
lua基金会【五岁以下儿童】I/O文件操作
查看>>
一个小的日常实践——高速Fibonacci数算法
查看>>
创建与删除索引
查看>>