文章目录
数据与文字的表示方法
计算机要存储、处理数据首先要解决如何表示数据的问题,这一步是规定数据的表示规则,例如采用什么进制,如何表示整数,小数(浮点数),如何表示字符汉字等。
常见的数据的格式
分类
##### 按数制划分
- 十进制:符合人的使用习惯,但微机中直接运算困难
- 二进制:占用存储空间稍多,精简上易于实现,易于运算
- 十六进制:占用空间少,简洁
- 二-十进制:采用4为二进制数表示1位十进制数,转换方便
按数据格式划分
- 真值:没有经过编码的直观数据表示,其值可以带正负号,热河进制均可
- 机器数:符号化后的数值(包括正负号的表示),一般位数固定(8、16、32…),不能忽略任何位置上的0或1
按数据的表示范围划分
- 定点数:小数点位置固定,数据表示范围小
- 浮点数:小数点位数不固定,数据表示范围大
按能否表示负数划分
- 无符号数:所有位数均表示数值
- 有符号数:有正负之分,最高位为符号位,其余位表示数值
进制
生活中我们使用的是十进制,计算机中数据的使用的是二进制,也用八进制和十六进制。
除了以上还有:
- 十二进制:月份的进制,钟表的小时进制
- 六十进制:分钟的进制
- 三进制、四进制、五进制、N进制
当然,进制有很多,理论上讲可以有无限多种进制,只需满足一个条件,进制的基数>1
即可,如果使用一进制,那么,这个进制就和结绳计数差不多了,对表示大的数据无意义。
进制的表示
以上所述的进制均属于位置记数发,这种数的表示法发明归功于苏马连人或比伦人,后为印度人发展,这种发明对人类的文明的有巨大的意义,他使数的表示更为方便简答 [ 引 ] ^{[引]} [引],这种数的表示方法需要两个一个基底,例如十进制的基底是10
,二进制的基底是2
,其次是需要一些符号表示数,通常是阿拉伯数字,例如二进制使用0、1
,这些数都是小于基底的数。
进制转换
在位置计数法中进制转换有个不变的规则:除基底取余数
,这是数是模基底的数,例如十进制转换为二进制就需要不断取模2的数。
二进制表示: [ N ] 2 = a n ∗ 2 n + ⋯ + a 2 ∗ 2 2 + a 1 ∗ 2 1 + a 0 ∗ 2 0 = N u m [N]_2 =a_n*2^n + \dots + a_2*2^2 + a_1*2^1 + a_0*2^0 = Num [N]2=an∗2n+⋯+a2∗22+a1∗21+a0∗20=Num
其中 a n , … , a 2 , a 1 , a 0 a_n ,\dots, a_2 , a_1 , a_0 an,…,a2,a1,a0 是二进制数序列(模2的数,即余数),
2 n , … , 2 2 , 2 1 , 2 0 2^n,\dots,2^2,2^1,2^0 2n,…,22,21,20 是二进制的权值,例如在十进制中 1 0 3 10^3 103表示1000的权值, 1 0 2 10^2 102表示100的权值。
示例:
-
十进制转换二进制
-
[ 25 ] 2 = [25]_{2} = [25]2= 25 2 余 1 ⇒ \frac{25}{2}余 1 \Rightarrow 225余1⇒ 12 2 余 0 ⇒ \frac{12}{2}余 0 \Rightarrow 212余0⇒ 6 2 余 0 ⇒ \frac{6}{2}余0 \Rightarrow 26余0⇒ 3 2 余 1 ⇒ \frac{3}{2}余1 \Rightarrow 23余1⇒ 1 2 余 1 \frac{1}{2}余1 21
-