进制转换内容总结

今天接触了进制转换的内容,即十进制,二进制,八进制,十六进制之间的相互转换。

一、基础内容

十进制:有十个基数 0,1,2,3,4,5,6,7,8,9

二进制:逢二进一,借一为二。

基数为0,1

八进制:逢八进一,借一为八。

基数为0,1,2,3,4,5,6,7

十六进制:逢十六进一,借一为十六。

基数为0,1,2,3,4,5,6,7,8,9,A(10),B(11),C(12),D(13),E(14),F(15)

二、转换方法

1、十进制与其他进制(二、八、十六)

十进制→ 二进制:十进制数除以二,除至0后,所得余数按照反方向写出即可。(如图所示)

十进制→ 八进制:十进制数逐次整除八,直至商为0,所得余数按照反方向写出即可。

(同理,把上图中2换成8计算即可)

十进制→ 十六进制:十进制数逐次整除十六,直至商为0,所得余数按照反方向写出即可,但要注意10及其以上的数字用字母A-F表示。

(同理,把上图中2换成16计算即可)

2、其他进制(二、八、十六)与十进制

注意:a---m方向为从右到左

二进制→十进制:a×20+b×21+c×22+d×23+…….+m×2(n-1)

例如:将二进制的(101011)转换为十进制的步骤如下:

1. 第0位 1 x 2^0 = 1;

2. 第1位 1 x 2^1 = 2;

3. 第2位 0 x 2^2 = 0;

4. 第3位 1 x 2^3 = 8;

5. 第4位 0 x 2^4 = 0;

6. 第5位 1 x 2^5 = 32;

7. 读数,把结果值相加,1+2+0+8+0+32=43


二进制位数(从右到左)


第一位


第二位


第三位


第四位


第五位


第六位


第七位


第八位


对应的2的次方


2^0


2^1


2^2


2^3


2^4


2^5


2^6


2^7


对应结果


1


2


4


8


16


32


64


128

八进制→十进制:a×80+b×81+c×82+d×83+…….+m×8(n-1)

例如:将八进制的(53)转换为十进制的步骤如下:

1. 第0位 3 x 8^0 = 3;

2. 第1位 5 x 8^1 = 40;

3. 读数,把结果值相加,3+40=43(8)


八进制位数(从右到左)


第一位


第二位


第三位


第四位


第五位


第六位


第七位


第八位


对应的8的次方


8^0


8^1


8^2


8^3


8^4


8^5


8^6


8^7


对应结果


1


8


64


512


4096


32768


262144


2097152

十六进制→十进制:a×160+b×161+c×162+d×163+…….+m×16(n-1)

例:将十六进制的(2B)转换为十进制的步骤如下:

1. 第0位 B x 16^0 = 11;

2. 第1位 2 x 16^1 = 32;

3. 读数,把结果值相加,11+32=43(16)


十六进制位数(从右到左)


第一位


第二位


第三位


第四位


对应的16的次方


16^0


16^1


16^2


16^3


对应结果


1


16


256


4096

3、其他进制之间的转换

二进制→八进制:对于整数,采用从右到左每三位一组,不够三位的在其左边补齐0,每组单独转换出来即可。

例如:转换二进制数 1110101010100 那么分组为
001 110 101 010 100 按照转换方法对应转换
  1    6    5    2 
  4
所以
1110101010100(2) = 16524(8)

八进制→二进制:将每位八进制由三位二进制数代替即可。

二进制与八进制编码对应表:


二进制


八进制


000


0


001


1


010


2


011


3


100


4


101


5


110


6


111


7

二进制→十六进制:此时分组为从右到左每 4 位二进制数为一组进行转换

例如:转换二进制 0101010100101011010,分组:
0010 1010 1001 0101 1010
   2     A      9      5      A
所以0101010100101011010(2)
= 2A95A(16)

十六进制→二进制:将每位十六进制由四位二进制数代替即可。

二进制和十六进制的互相转换比较重要。不过这二者的转换却不用计算,每个C,C++程序员都能做到看见二进制数,直接就能转换为十六进制,反之亦然。

首先我们来看一个二进制数:1111,它是多少呢?

你可能还要这样计算:1 *
2 + 1 * 2 + 1 * 2 + 1 * 2 = 1 * 1 + 1 * 2 + 1 * 4 + 1 * 8 = 15。

然而,由于1111才4位,所以我们必须直接记住它每一位的权值,并且是从高位往低位记,:8、4、2、1。即,最高位的权值为2^3
= 8,然后依次是 2^2 = 4,2^1=2, 2^0 = 1。

记住8421,对于任意一个4位的二进制数,我们都可以很快算出它对应的10进制值。


仅四位的二进制数


快速计算方法


十进制值


十六进制值


1111


8+4+2+1


15


F


1110


8+4+2+0


14


E


1101


8+4+0+1


13


D


1100


8+4+0+0


12


C


1011


8+0+2+1


11


B


1010


8+0+2+0


10


A


1001


8+0+0+1


9


9


……


0001


0+0+0+1


1


1


0000


0+0+0+0


0


0

4、下面是二、八、十、十六进制之间关系的结构图:

5、几个进制之间的对应关系:

时间: 2024-08-23 21:24:06

进制转换内容总结的相关文章

03 php 数据类型:整数,进制转换,浮点,字符,布尔,数组,空类型,类型转换,算术运算,比较运算

03 数据类型:整数,进制转换,浮点,字符,布尔,数组,空类型,类型转换, 算术运算,比较运算,逻辑运算,短路现象, 三目运算符,字符型运算: 数据类型 整体划分 标量类型: int, float, string, bool 复合类型: array,     object 特殊类型: null,     resouce 整数类型int, integer 3种整数表示法 十进制写法:123: $n1 = 123; 八进制写法: 0123 $n2 = 0123; 十六进制写法: 0x123 $n3

大数进制转换问题

在数据结构课关于栈的这一章中,我们都学过用"模2取余法"来将一个10进制数转换为一个二进制数,进而可以推广到"模n取余法",经其转换为n进制(n任意指定). 确实,这是一个很基础的题目,可你是否想过如果这个10进制数是一个大数(其位数可能上千位,此时用一般数据类型肯定是会溢出的),那么这个问题又如何来求解呢? 当然,也许你会说很简单嘛,自己写一个大数类(当然至少要写一个大数除法才行),或者你用的是Java这种现代化语言,就更轻松了,直接用BigInteger这样的大

shell进制转换

使用 Shell 运算进行进制转换 假定在您的脚本中有一些数字,您需要以另外的进制处理这些数字.使用 Shell 运算可以很容易地自动实现这类转换.一种情况是使用 Shell 运算把一个数字从给定的进制转换位十进制.如果数字以运算展开式的形式提供,那么假定它带有十进制符号,除非 它前面带有 0(这种情况假定是八进制)或 0x(这种情况假定是十六进制).键入以下内容以得到一些八进制和十六进制值的十进制输出: $ echo $((013)) $ echo $((0xA4)) 您还可以使用以下格式指定

进制转换( C++字符数组 )

注: 较为简便的方法是用 整型(int)或浮点型(long.double 注意:该类型不一定能够准确存储数据) 来存放待转换的数值,可直接取余得到每一位数值 较为稳定的方法是用 字符数组储存待转换的数值,这将能够完整存储数据,但是也相对于代码较长 进制转换只需要两步: R -> 十  或者  十 -> R  (R表示除十进制的任意进制,10表示十进制) 以下是较为完整的全部代码,若是实现如何转换的,主看: void Ten_Other(char[],int,int,char[],int&

进制转换、基础语音、语句的总结与练习

C#阶段总结 一.进制转换 计算机中采用的是二进制,因为二进制具有运算简单,易实现且可靠,为逻辑设计提供了有利的途径.节省设备等优点. 我们常用的进制还有八进制.十进制.十六进制,其特点是: (1)逢N进一  N是每种进位计数制表示一位数所需要的符号数目为基数. 二进制:逢二进一,借一当二 八进制:逢八进一,借一当八 十六进制:逢十六进一,借一当十六 (2)数制转换  不同进位计数制之间的转换原则:不同进位制之间的转换是根据两个有理数如相等,则两数的整数部分和分数部分一定分别相等的原则进行的.也

一起talk C栗子吧(第七回:C语言实例--进制转换)

各位看官们.大家好,从今天開始.我们讲大型章回体科技小说 :C栗子,也就是C语言实例. 闲话休提, 言归正转.让我们一起talk C栗子吧! 看官们.上一回中咱们说的是生成随机数的样例.这一回咱们说的样例是:进制转换.说到进制预计大家 都不陌生.计算机中的进制有二进制.八进制,十进制,十六进制. 今天咱们将要说的是十进制怎样转换成二进制.八进制和十六进制.在这里我把敲代码的步骤和算法思路 写出来供大家參考. 1.获取用户想要转换的数值和想到转换的进制.这里要检查输入是否正确.这是程序健壮性的体现

Java基础笔记(3) 进制与进制转换

---恢复内容开始--- 进制 在一般生活中,我们一直在应用的十进制,就是逢十进一,而今天我们要接触的是,计算机编程常用的进制!首先我们要知道,计算机内部运算采用的是二进制,也就是逢二进制! 1.什么是二进制? 就是只有0 和 1  每当遇到值为2 就向前进一位. 2.为什么计算机内部是二进制? 这就要从硬件说起,计算机是如何储存数据的,要知道我们网络传输,就是你要和别人一起聊天,你们隔着很远,到底是怎样才能让他收到你的聊天内容? 有一根网线还能说过去,毕竟网线链接终端我们也不知道连到哪,保不齐

获取码值和进制转换系统(包括正负数、小数)

获取码值和进制转换 程序由来: 本人发现计算机中的计算器木有将十进制小数转二进制的功能,后来发现一些网站将十进制负数转二进制只是求出整数的二进制,然后前面加"-",这种表示不是真正的负数二进制.于是爱较真儿的我写了一个可以转十进制小数.负数.负数加小数为二进制的系统,供大家学习参考.介于理解代码,代码中运用到了纯拼音.虽然是拼音,但符合代码编写格式.介于个人知识有限,代码如有需要修改和改进的地方,敬请大家评教指正,共同学习. 实现功能: 获取字符的码值,包括中文. 进制转换包括:十进制

获取码值(各种类型字符(中、英)的ASCII)和进制转换系统(包括正负数、小数)

获取码值和进制转换 程序由来: 本人发现计算机中的计算器木有将十进制小数转二进制的功能,后来发现一些网站将十进制负数转二进制只是求出整数的二进制,然后前面加"-",这种表示不是真正的负数二进制.于是爱较真儿的我写了一个可以转十进制小数.负数.负数加小数为二进制的系统,供大家学习参考.介于理解代码,代码中运用到了纯拼音.虽然是拼音,但符合代码编写格式.介于个人知识有限,代码如有需要修改和改进的地方,敬请大家评教指正,共同学习. 实现功能: 获取字符的码值,包括中文. 进制转换包括:十进制