精华内容
下载资源
问答
  • 十进制转换八进制

    2014-09-28 01:22:06
    栈的应用举例,由于没给出完整源码,自己写了一个比较完整的
  • 其方法与二进制转换十进制差不多:按权相加法,即将八进制每位上的数乘以位权(如8,64,512….),然后将得出来的数再加在一起。 如将72.45转换为十进制。如图1所示 来看看十进制八进制,有两种方法:直接法与...

    先来看八进制如何转换成十进制。其方法与二进制转换成十进制差不多:按权相加法,即将八进制每位上的数乘以位权(如8,64,512….),然后将得出来的数再加在一起。
    如将72.45转换为十进制。如图1所示
    在这里插入图片描述
    来看看十进制转八进制,有两种方法:直接法与间接法,先看直接的方法,与十进制转成二进制相同,咱们还是分整数部分转换和小数部分转换。
    整数部分,除8取余法,每次将整数部分除以8,余数为该位权上的数,商继续除以8,余数又为上一个位权上的数,然后以此类推一直下去,直到商为零,最后从最后一个余数向前排列就可以了,嗨,还是上图直观,如图2所示。
    在这里插入图片描述
    再看小数部分,与转二进制相同,这里是乘八取整法,也就是说小数部分乘以8,然后取整数部分,再让剩下的小数部分再乘以8,再取整数部分,……以此类推,一直乘到小数部分为零为止。例如0.13856,如图3所示。
    在这里插入图片描述
    小数部分乘以8,如果永远也碰不到零该怎么办?如图4所示(假设示范哦),那就根据位数要求进行“3舍4入”吧。
    在这里插入图片描述
    这个是直接的方法,还有一个间接的方法捏?就是先把十进制转换为二进制,然后再由二进制转换为8进制,例如将十进制478.0245转为八进制。

        先转为二进制为(转换方法这里就不再累述了哦,不知道的看上期介绍吧):
    
        (478.125)10=(111011110.001)2
    
        二进制再转为八进制为(转换方法这里就不再累述了哦,不知道的看上期介绍吧):
    
        (111011110.001)2=(736.1)8
    

    注意事项:
    八进制转十进制:整体顺序、小数点不变,个位乘8的0次方+十位乘8的1次方…=十进制得数,即可。小数部分从左到右乘8的负一次方开始,以此类推。
    十进制转八进制:整体顺序、小数点不变,整数部分除8,余数倒着从左向右排,小数部分乘8,整数自左向右排。

    展开全文
  • 十进制八进制转换方法

    万次阅读 多人点赞 2020-03-23 14:57:59
    1.间接法:先将十进制转换成二进制,然后将二进制又转换成八进制 。 2.直接法:前面我们讲过,八进制是由二进制衍生而来的,因此我们可以采用与十进制转换为二进制相类似的方法,分为整数部分的转换和小数部分的...

    1.间接法:先将十进制转换成二进制,然后将二进制又转换成八进制  。

    2.直接法:前面我们讲过,八进制是由二进制衍生而来的,因此我们可以采用与十进制转换为二进制相类似的方法,分为整数部分的转换和小数部分的转换:

    • 整数部分方法:除8取余法,即每次将整数部分除以8,余数为该位权上的数,而商继续除以8,余数又为上一个位权上的数,这个步骤一直持续下去,直到商为0为止
    • 最后读数时候,从最后一个余数起,一直到最前面的一个余数。 

    上面参考来源:https://zhidao.baidu.com/question/86924187.html

    图片参考来源:https://jingyan.baidu.com/album/a3a3f811f7ab518da2eb8acb.html?picindex=2

    JAVA实现:

            Scanner scanner = new Scanner(System.in);
            System.out.println("请输入值:");
            int n=scanner.nextInt();
            String s="";
            while(n>0){
                s=n%8+" "+s;
                n=n/8;
            }
            System.out.println(s);

     

    展开全文
  • 举例:十进制 91=9X10+1;八进制 76=7X8+6=62;十六进制11=1X16+1=17.十六进制的10到16用字母表示。 依次为1,2,3,4,5,6,7,8,9,A,B,C,D,E,F ,16

    举例:

    十进制 91=9X10+1;

    八进制 76=7X8+6=62;

    十六进制11=1X16+1=17.十六进制的10到16用字母表示。
    依次为1,2,3,4,5,6,7,8,9,A,B,C,D,E,F ,16

    展开全文
  • 一.本文所涉及的内容(Contents) ... 八进制十进制 十六进制 → 十进制十进制) → (二、八、十六进制) 十进制 → 二进制 十进制八进制 十进制 → 十六进制 (...

    一.本文所涉及的内容(Contents)

                         目录

    一.本文所涉及的内容(Contents)

    二.背景(Contexts)

    三.进制转换算法(Convert)

    (一) (二、八、十六进制) → (十进制)

    (二) (十进制) → (二、八、十六进制)

    (三) (二进制) ↔ (八、十六进制)

    (四) (八进制) ↔ (十六进制)

    四.扩展阅读

    五.参考文献(References)


    二.背景(Contexts)

      之前使用SQL把十进制的整数转换为三十六进制,SQL代码请参考:SQL Server 进制转换函数,其实它是基于二、八、十、十六进制转换的计算公式的,进制之间的转换是很基础的知识,但是我发现网络上没有一篇能把它说的清晰、简单、易懂的文章,所以我才写这篇文章的念头,希望能让你再也不用担心、害怕进制之间的转换了。

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

    wpsC01D.tmp

    (Figure1:进制关系结构图)

    下文会分4个部分对这个图进行分解,针对每个部分会以图文的形式进行讲解:

    1. (二、八、十六进制) → (十进制);
    2. (十进制) → (二、八、十六进制);
    3. (二进制) ↔ (八、十六进制);
    4. (八进制) ↔ (十六进制);

    三.进制转换算法(Convert)

      在数字后面加上不同的字母来表示不同的进位制。B(Binary)表示二进制,O(Octal)表示八进制,D(Decimal)或不加表示十进制,H(Hexadecimal)表示十六进制。例如:(101011)B=(53)O=(43)D=(2B)H

    (一) (二、八、十六进制) → (十进制)

    wpsC01E.tmp

    (Figure2:其他进制转换为十进制)

    • 二进制 → 十进制

      方法:二进制数从低位到高位(即从右往左)计算,第0位的权值是2的0次方,第1位的权值是2的1次方,第2位的权值是2的2次方,依次递增下去,把最后的结果相加的值就是十进制的值了。

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

    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,即(101011)B=(43)D。

    • 八进制 → 十进制

      方法:八进制数从低位到高位(即从右往左)计算,第0位的权值是8的0次方,第1位的权值是8的1次方,第2位的权值是8的2次方,依次递增下去,把最后的结果相加的值就是十进制的值了。

      八进制就是逢8进1,八进制数采用 0~7这八数来表达一个数。

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

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

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

    3. 读数,把结果值相加,3+40=43,即(53)O=(43)D。

    • 十六进制 → 十进制

      方法:十六进制数从低位到高位(即从右往左)计算,第0位的权值是16的0次方,第1位的权值是16的1次方,第2位的权值是16的2次方,依次递增下去,把最后的结果相加的值就是十进制的值了。

      十六进制就是逢16进1,十六进制的16个数为0123456789ABCDEF。

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

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

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

    3. 读数,把结果值相加,11+32=43,即(2B)H=(43)D。

    (二) (十进制) → (二、八、十六进制)

    wpsC01F.tmp

    (Figure3:十进制转换为其它进制)

    • 十进制 → 二进制

      方法:除2取余法,即每次将整数部分除以2,余数为该位权上的数,而商继续除以2,余数又为上一个位权上的数,这个步骤一直持续下去,直到商为0为止,最后读数时候,从最后一个余数读起,一直到最前面的一个余数。 

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

    1. 将商43除以2,商21余数为1;

    2. 将商21除以2,商10余数为1;

    3. 将商10除以2,商5余数为0;

    4. 将商5除以2,商2余数为1;

    5. 将商2除以2,商1余数为0; 

    6. 将商1除以2,商0余数为1; 

    7. 读数,因为最后一位是经过多次除以2才得到的,因此它是最高位,读数字从最后的余数向前读,101011,即(43)D=(101011)B。

    wpsC02F.tmp

    (Figure4:图解十进制 → 二进制)

    • 十进制 → 八进制

      方法1:除8取余法,即每次将整数部分除以8,余数为该位权上的数,而商继续除以8,余数又为上一个位权上的数,这个步骤一直持续下去,直到商为0为止,最后读数时候,从最后一个余数起,一直到最前面的一个余数。

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

    1. 将商796除以8,商99余数为4;

    2. 将商99除以8,商12余数为3;

    3. 将商12除以8,商1余数为4;

    4. 将商1除以8,商0余数为1;

    5. 读数,因为最后一位是经过多次除以8才得到的,因此它是最高位,读数字从最后的余数向前读,1434,即(796)D=(1434)O。

    wpsC030.tmp

    (Figure5:图解十进制 → 八进制)

      方法2:使用间接法,先将十进制转换成二进制,然后将二进制又转换成八进制;

    wpsC031.tmp

    (Figure6:图解十进制 → 八进制)

    • 十进制 → 十六进制

      方法1:除16取余法,即每次将整数部分除以16,余数为该位权上的数,而商继续除以16,余数又为上一个位权上的数,这个步骤一直持续下去,直到商为0为止,最后读数时候,从最后一个余数起,一直到最前面的一个余数。

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

    1. 将商796除以16,商49余数为12,对应十六进制的C;

    2. 将商49除以16,商3余数为1;

    3. 将商3除以16,商0余数为3;

    4. 读数,因为最后一位是经过多次除以16才得到的,因此它是最高位,读数字从最后的余数向前读,31C,即(796)D=(31C)H。

    wpsC042.tmp

    (Figure7:图解十进制 → 十六进制)

      方法2:使用间接法,先将十进制转换成二进制,然后将二进制又转换成十六进制;

    wpsC043.tmp

    (Figure8:图解十进制 → 十六进制)

    (三) (二进制) ↔ (八、十六进制)

    wpsC044.tmp

    (Figure9:二进制转换为其它进制)

    • 二进制 → 八进制

      方法:取三合一法,即从二进制的小数点为分界点,向左(向右)每三位取成一位,接着将这三位二进制按权相加,然后,按顺序进行排列,小数点的位置不变,得到的数字就是我们所求的八进制数。如果向左(向右)取三位后,取到最高(最低)位时候,如果无法凑足三位,可以在小数点最左边(最右边),即整数的最高位(最低位)添0,凑足三位。

      例:将二进制的(11010111.0100111)B转换为八进制的步骤如下:

    1. 小数点前111 = 7;

    2. 010 = 2;

    3. 11补全为011,011 = 3;

    4. 小数点后010 = 2;

    5. 011 = 3;

    6. 1补全为100,100 = 4;

    7. 读数,读数从高位到低位,即(11010111.0100111)B=(327.234)O。

    wpsC054.tmp

    (Figure10:图解二进制 → 八进制)

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

    二进制

    八进制

    000

    0

    001

    1

    010

    2

    011

    3

    100

    4

    101

    5

    110

    6

    111

    7

     

    • 八进制 → 二进制

      方法:取一分三法,即将一位八进制数分解成三位二进制数,用三位二进制按权相加去凑这位八进制数,小数点位置照旧。

      例:将八进制的(327)O转换为二进制的步骤如下:

    1. 3 = 011;

    2. 2 = 010;

    3. 7 = 111;

    4. 读数,读数从高位到低位,011010111,即(327)O=(11010111)B。

    wpsC055.tmp

    (Figure11:图解八进制 → 二进制)

    • 二进制 → 十六进制

      方法:取四合一法,即从二进制的小数点为分界点,向左(向右)每四位取成一位,接着将这四位二进制按权相加,然后,按顺序进行排列,小数点的位置不变,得到的数字就是我们所求的十六进制数。如果向左(向右)取四位后,取到最高(最低)位时候,如果无法凑足四位,可以在小数点最左边(最右边),即整数的最高位(最低位)添0,凑足四位。

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

    1. 0111 = 7;

    2. 1101 = D;

    3. 读数,读数从高位到低位,即(11010111)B=(D7)H。

    wpsC056.tmp

    (Figure12:图解二进制 → 十六进制)

    • 十六进制 → 二进制

      方法:取一分四法,即将一位十六进制数分解成四位二进制数,用四位二进制按权相加去凑这位十六进制数,小数点位置照旧。

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

    1. D = 1101;

    2. 7 = 0111;

    3. 读数,读数从高位到低位,即(D7)H=(11010111)B。

    wpsC057.tmp

    (Figure13:图解十六进制 → 二进制)

    (四) (八进制) ↔ (十六进制)

    wpsC058.tmp

    (Figure14:八进制与十六进制之间的转换)

    • 八进制 → 十六进制

      方法:将八进制转换为二进制,然后再将二进制转换为十六进制,小数点位置不变。

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

    1. 3 = 011;

    2. 2 = 010;

    3. 7 = 111;

    4. 0111 = 7;

    5. 1101 = D;

    6. 读数,读数从高位到低位,D7,即(327)O=(D7)H。

    wpsC069.tmp

    (Figure15:图解八进制 → 十六进制)

    • 十六进制 → 八进制

      方法:将十六进制转换为二进制,然后再将二进制转换为八进制,小数点位置不变。

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

    1. 7 = 0111;

    2. D = 1101;

    3. 0111 = 7;

    4. 010 = 2;

    5. 011 = 3;

    6. 读数,读数从高位到低位,327,即(D7)H=(327)O。

    wpsC06A.tmp

    (Figure16:图解十六进制 → 八进制)

    四.扩展阅读

      1. 包含小数的进制换算:

    (ABC.8C)H=10x16^2+11x16^1+12x16^0+8x16^-1+12x16^-2

    =2560+176+12+0.5+0.046875

    =(2748.546875)D

      2. 负次幂的计算:

    2^-5=2^(0-5)=2^0/2^5=1/2^5

    同底数幂相除,底数不变,指数相减,反过来

    3. 我们需要了解一个数学关系,即23=8,24=16,而八进制和十六进制是用这关系衍生而来的,即用三位二进制表示一位八进制,用四位二进制表示一位十六进制数。接着,记住4个数字8、4、2、1(23=8、22=4、21=2、20=1)。

    五.参考文献(References)

    二进制、八进制、十进制、十六进制之间转换

    二进制如何转换成八进制

    展开全文
  • 八进制十进制的互相转换

    千次阅读 2020-06-18 14:55:47
    B(Binary)表示二进制,O(Octal)表示八进制,D(Decimal)或不加表示十进制,H(Hexadecimal)表示十六进制。例如:(101011)B=(53)O=(43)D=(2B)H 一、八进制十进制 描述:八进制就是逢8进1,八进制数采用 0~...
  • 计算机进制转换:二进制、八进制十进制、十六进制 一、什么是进制 在生活中,我们通常都是使用阿拉伯数字计数的,也就是10进制,以10为单位,遇10进一,所以是由0,1,2、3、4、5、6、7、8、9组成的;而在计算机中...
  • Sometimes we need to convert an integer value which is in decimal format to the octal string in JavaScript or need a decimal... 有时,我们需要将十进制格式的整数值转换为JavaScript中的八进制字符串,或者...
  • 十进制转化为八进制的算法Converting a number from Decimal to Octal is almost similar to converting Decimal into Binary, although just one difference is that unlike Binary conversion, here in an ...
  • 二进制、八进制十进制、十六进制关系及转换

    万次阅读 多人点赞 2019-02-21 21:20:22
    二进制,八进制十进制,十六进制之间的关系是什么?浮点数是什么回事? 本文内容参考自王达老师的《深入理解计算机网络》一书<中国水利水电出版社&amp...
  • 将二进制、八进制、十六进制转换为十进制二进制、八进制和十六进制向十进制转换都非常容易,就是“按权相加”。所谓“权”,也即“位权”。假设当前数字是N进制,那么:对于整数部分,从右往左看,第 i 位的位权等于...
  • 十进制转换

    2019-06-22 00:24:40
    进制转换十进制转化成其他进制) 通俗所见十进制:1+9=10,2+18=10; ,当然都是大家会的,也是我们人在计算机最直接得可以计算的结果。但计算机其实是只有1和0 两个单数。就会涉及到其他的进制转换,常见二进制...
  • 进制转换二进制转八进制十进制,十六进制二进制转八进制二进制转十进制二进制转十六进制八进制转二进制,十进制,十六进制八进制转二进制八进制十进制八进制转十六进制十进制转二进制,八进制,十六进制十进制转...
  • #include<stdio.h> #include<stdlib.h> int main() { char *p; char s[6]; int n; p = s; gets(p); n = 0; while (*(p) != '\0') { n = n * 8 + *p - '0'; p++;... sys...
  • C语言经典例82-八进制转换十进制

    千次阅读 2020-02-20 13:04:00
    将一个八进制数,逐一分解出对应的权值,再乘以权重,累加起来就可以转换十进制了,采用具体的方法就是除余法,例如八进制数12,取余分解出最低位2,再乘以相应的权重,由于是最低位,所以权重为 80=18^0 = 180=1 ...
  • C语言将八进制转换十进制C语言将八进制转换十进制完整源码 C语言将八进制转换十进制完整源码 int convertValue(int num, int i) { return num * pow(8, i); } long long toDecimal(int octal_value) { ...
  • 2、八进制:八个符号,由0~7八个数字组成。开头一般以0开头。 3、十进制:十个符号,由0~9十个数字组成,不能以0开头。是咋们日常生活中最常用的数字。 4、十六进制:十六个符号,由0~9个数字和a-f组成。a表示数字10...
  • 文章目录一、心算法1、二进制转换十进制2、八进制转换十进制3、十六进制转换十进制如何快速的进行 2进制,16进制 的 相互转换二、python转换方法binocthexint 一、心算法 首先我们只需要知道二进制和十进制,二进制和...
  • 2、十进制转换为二进制、八进制、十六进制进制。 方法:整数部分采用除基数取余法;小数部分采用乘基数取整法。 例如:十进制(244.6875)转换为二进制数? 3、二进制转换为八进制、十六进制。 方法:以小数点为...
  • 十进制八进制C++做法

    千次阅读 2020-10-18 12:28:18
    描述:把任一给定的十进制正整数转换八进制数输出。 方法一:指针 #include <bits/stdc++.h> using namespace std; int main() { int d; vector<int> vec; cin>>d; while (d) { vec....
  • 十六进制转换八进制

    千次阅读 2018-11-29 13:44:31
     先将十六进制数转换成某进制数,再由某进制数转换八进制。 算法分析 代码如下 #include #include int x2i(char c) { if (c >= 'A') return c - 55; else return c - 48; } int main() { int i,...
  • 计算机网络基础之进制之间转换(二进制、八进制十进制、十六进制目录)计算机网络基础之进制之间转换(二进制、八进制十进制、十六进制)1、十进制转二进制2、十进制八进制3、十进制转十六进制4、二进制转...
  • 二、、十六进制转换(图解篇)

    万次阅读 多人点赞 2017-11-14 21:49:06
    各种进制的用途 10进制,当然是便于我们人类来使用,我们从小的习惯就是使用十进制,这个毋庸置疑。 2进制,是供计算机使用的,1,0代表开和关,有和无,机器只...二进制、八进制十进制、十六进制之间的转换 ht
  •  之前使用SQL把十进制的整数转换为三十六进制,SQL代码请参考:SQL Server 进制转换函数,其实它是基于二、、十、十六进制转换的计算公式的,进制之间的转换是很基础的知识,但是我发现网络上没有一篇能把它说的...
  • 关于进制计算的公式(转换十进制)

    千次阅读 2018-05-09 11:07:52
    设x为进制,y为第几位(0位开始),z为数字示例: 八进制 00030102,则x=8,y分别为...z为3,1,2 转换十进制为: 8 ** 0 * 2 + 8 ** 2 * 1 + 8 ** 4 * 3 = 12354同理:二进制 00001111 转换十进制为: 2 ** 0 * 1 + 2 *...
  • 1、其他进制转十进制 二进制转十进制 计算公式:从最低位开始(右边起),将每个位上的数提取出来,乘于2的(位数-1)次方,然后求和 ... 八进制十进制 计算公式:从最低位开始(右边起),将每个位上.
  • 0b 表示二进制 0 1 0o 表示八进制 0 1 2 3 4 5 6 7 0x 表示十六进制 0 1 2 3 4 5 6 7 8 9 a b c d e f
  • C语言,将一个八进制转换十进制数(含延伸) 设计思路,将八进制数用字符串的形式输入储存,然后按照每一位对应的8的指数级与该位相乘,再把每一位的结果相加,得到需要转换十进制数。 #include<studio.h&...
  • 任意进制转换十进制

    千次阅读 2019-07-19 11:08:33
    公式:数字 × 进制 ×^...十六进制转换十进制:范围[0-9,a-f], 前缀“0x” 0x549fa:5 × 16^4 + 4× 16^3 + 9 × 16^2 + 15 × 16^1 + 10× 16^0=略 十进制十进制:12345 = 1 × 10^4 + 2 × 10^3 + 3 × 10^...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 9,008
精华内容 3,603
关键字:

十进制转换八进制公式