zoukankan      html  css  js  c++  java
  • 感悟C语言的特点

    计数的学问——进制

    • 十进制

    上学之初,我们就学过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”。
    • 其他进制——八进制,十六进制

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

  • 相关阅读:
    http://www.cplusplus.com/reference/string/string/find_last_of/

    SQL Server数据库设计表和字段的经验
    AMP产品识别
    水晶头AMP识别
    双绞线的规范和制作经验谈
    VB.net 产生随机验证码
    手把手教您架设Windows2003共享服务器
    使用EasyRecovery Pro 6.04恢复RAW格式硬盘的数据实战
    .NET中各种数据库连接大全
  • 原文地址:https://www.cnblogs.com/shudibo/p/2842633.html
Copyright © 2011-2022 走看看