二进制数转换成十进制数Word格式文档下载.docx

上传人:b****5 文档编号:15945008 上传时间:2022-11-17 格式:DOCX 页数:18 大小:25.29KB
下载 相关 举报
二进制数转换成十进制数Word格式文档下载.docx_第1页
第1页 / 共18页
二进制数转换成十进制数Word格式文档下载.docx_第2页
第2页 / 共18页
二进制数转换成十进制数Word格式文档下载.docx_第3页
第3页 / 共18页
二进制数转换成十进制数Word格式文档下载.docx_第4页
第4页 / 共18页
二进制数转换成十进制数Word格式文档下载.docx_第5页
第5页 / 共18页
点击查看更多>>
下载资源
资源描述

二进制数转换成十进制数Word格式文档下载.docx

《二进制数转换成十进制数Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《二进制数转换成十进制数Word格式文档下载.docx(18页珍藏版)》请在冰豆网上搜索。

二进制数转换成十进制数Word格式文档下载.docx

  二进制转十进制

  从最后一位开始算,依次列为第0、1、2...位

  第n位的数(0或1)乘以2的n次方

  得到的结果相加就是答案

  例如:

01101011.转十进制:

  第0位:

1乘2的0次方=1

  1乘2的1次方=2

  0乘2的2次方=0

  1乘2的3次方=8

  0乘2的4次方=0

  1乘2的5次方=32

  1乘2的6次方=64

  0乘2的7次方=0

  然后:

1+2+0

  +8+0+32+64+0=107.

  二进制01101011=十进制107.

  由二进制数转换成十进制数的基本做法是,把二进制数首先写成加权系数展开式,然后按十进制加法规则求和。

这种做法称为"

按权相加"

法。

二进制转十进制

  本人有个更直接的方法,例如二进制数1000110转成十进制数可以看作这样:

  数字中共有三个1即第二位一个,第三位一个,第七位一个,然后十进制数即2的2-1次方+2的3-1次方+2的7-1次方即2+4+64=70次方数即1的位数减一。

如此计算只需要牢记2的前十次方即可在此本人为大家陈述一下:

2的0次方是1

  2的1次方是2

  2的2次方是4

  2的3次方是8

  2的4次方是16

  2的5次方是32

  2的6次方是64

  2的7次方是128

  2的8次方是256

  2的9次方是512

  2的10次方是1024

  2的11次方是2048

  2的12次方是4096

  2的13次方是8192

  2的14次方是16384

  2的15次方是32768

  2的16次方是65536

  在这里仅为您提供前16次方,若需要更多请自己查询。

编辑本段十进制数转换为二进制数

  十进制数转换为二进制数时,由于整数和小数的转换方法不同,所以先将十进制数的整数部分和小数部分分别转换后,再加以合并。

十进制转二进制

  110011

1.十进制整数转换为二进制整数

  十进制整数转换为二进制整数采用"

除2取余,逆序排列"

具体做法是:

用2去除十进制整数,可以得到一个商和余数;

再用2去除商,又会得到一个商和余数,如此进行,直到商为一时为止,然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。

  十进制整数转二进制

  如:

255=()B

  255/2=127=====余1

  127/2=63======余1

  63/2=31=======余1

  31/2=15=======余1

  15/2=7========余1

  7/2=3=========余1

  3/2=1=========余1

  1/2=0=========余1

2.十进制小数转换为二进制小数

  十进制小数转换成二进制小数采用"

乘2取整,顺序排列"

用2乘十进制小数,可以得到积,将积的整数部分取出,再用2乘余下的小数部分,又得到一个积,再将积的整数部分取出,如此进行,直到积中的整数部分为零,或者整数部分为1,此时0或1为二进制的最后一位。

或者达到所要求的精度为止。

  然后把取出的整数部分按顺序排列起来,先取的整数作为二进制小数的高位有效位,后取的整数作为低位有效位。

 

  十进制小数转二进制

0.625=(0.101)B

  0.625*2=1.25======取出整数部分1

  0.25*2=0.5========取出整数部分0

  0.5*2=1==========取出整数部分1

  再如:

0.7=(0.101100110...)B

  0.7*2=1.4========取出整数部分1

  0.4*2=0.8========取出整数部分0

  0.8*2=1.6========取出整数部分1

  0.6*2=1.2========取出整数部分1

  0.2*2=0.4========取出整数部分0 

0.2*2=0.4========取出整数部分0

(该版课程的内容更新及订正均已停止)

 

旧版课程打包下载

----------------------------------

[想看涵盖“面向对象”、“图形编程”、“泛型编程”……

的“最新2008年版白话C++”课程,请点击!

](另有:

博客版)

第六章 二进制、八进制、十六进制

6.1为什么需要八进制和十六进制?

6.2二、八、十六进制数转换到十进制数

6.2.1二进制数转换为十进制数

6.2.2八进制数转换为十进制数

6.2.3八进制数的表达方法

6.2.4八进制数在转义符中的使用

6.2.5十六进制数转换成十进制数

6.2.6十六进制数的表达方法

6.2.7十六进制数在转义符中的使用

6.3十进制数转换到二、八、十六进制数

6.3.110进制数转换为2进制数

6.3.210进制数转换为8、16进制数

6.4二、十六进制数互相转换

6.5原码、反码、补码

6.6通过调试查看变量的值

6.7本章小结

这是一节“前不着村后不着店”的课。

不同进制之间的转换纯粹是数学上的计算。

不过,你不必担心会有么复杂,无非是乘或除的计算。

生活中其实很多地方的计数方法都多少有点不同进制的影子。

比如我们最常用的10进制,其实起源于人有10个指头。

如果我们的祖先始终没有摆脱手脚不分的境况,我想我们现在一定是在使用20进制。

至于二进制……没有袜子称为0只袜子,有一只袜子称为1只袜子,但若有两袜子,则我们常说的是:

1双袜子。

生活中还有:

七进制,比如星期。

十六进制,比如小时或“一打”,六十进制,比如分钟或角度……

编程中,我们常用的还是10进制……必竟C/C++是高级语言。

比如:

inta=100,b=99;

不过,由于数据在计算机中的表示,最终以二进制的形式存在,所以有时候使用二进制,可以更直观地解决问题。

但,二进制数太长了。

比如int类型占用4个字节,32位。

比如100,用int类型的二进制数表达将是:

000000000000000001100100

面对这么长的数进行思考或操作,没有人会喜欢。

因此,C,C++没有提供在代码直接写二进制数的方法。

用16进制或8进制可以解决这个问题。

因为,进制越大,数的表达长度也就越短。

不过,为什么偏偏是16或8进制,而不其它的,诸如9或20进制呢?

2、8、16,分别是2的1次方,3次方,4次方。

这一点使得三种进制之间可以非常直接地互相转换。

8进制或16进制缩短了二进制数,但保持了二进制数的表达特点。

在下面的关于进制转换的课程中,你可以发现这一点。

二进制数第0位的权值是2的0次方,第1位的权值是2的1次方……

所以,设有一个二进制数:

01100100,转换为10进制为:

下面是竖式:

01100100换算成十进制

第0位0*20 

0

第1位0*21 

第2位1*22 

4

第3位0*23 

第4位0*24 

第5位1*25 

=32

第6位1*26 

=64

第7位0*27 

---------------------------

100 

用横式计算为:

0*20+0*21+1*22+1*23+0*24+1*25+1*26+0*27=100

0乘以多少都是0,所以我们也可以直接跳过值为0的位:

1*22+1*23+ 

1*25+1*26=100

八进制就是逢8进1。

八进制数采用0~7这八数来表达一个数。

八进制数第0位的权值为8的0次方,第1位权值为8的1次方,第2位权值为8的2次方……

所以,设有一个八进制数:

1507,转换为十进制为:

用竖式表示:

1507换算成十进制。

第0位7*80=7

第1位0*81=0

第2位5*82=320

第3位1*83=512 

--------------------------

839

同样,我们也可以用横式直接计算:

7*80+0*81+5*82+1*83=839

结果是,八进制数1507转换成十进制数为839

C,C++语言中,如何表达一个八进制数呢?

如果这个数是876,我们可以断定它不是八进制数,因为八进制数中不可能出7以上的阿拉伯数字。

但如果这个数是123、是567,或,那么它是八进制数还是10进制数,都有可能。

所以,C,C++规定,一个数如果要指明它采用八进制,必须在它前面加上一个0,如:

123是十进制,但0123则表示采用八进制。

这就是八进制数在C、C++中的表达方法。

由于C和C++都没有提供二进制数的表达方法,所以,这里所学的八进制是我们学习的,CtC++语言的数值表达的第二种进制法。

现在,对于同样一个数,比如是100,我们在代码中可以用平常的10进制表达,例如在变量初始化时:

inta=100;

我们也可以这样写:

inta=0144;

//0144是八进制的100;

一个10进制数如何转成8进制,我们后面会学到。

千万记住,用八进制表达时,你不能少了最前的那个0。

否则计算机会通通当成10进制。

不过,有一个地方使用八进制数时,却不能使用加0,那就是我们前面学的用于表达字符的“转义符”表达法。

我们学过用一个转义符'

\'

加上一个特殊字母来表示某个字符的方法,如:

'

\n'

表示换行(line),而'

\t'

表示Tab字符,'

则表示单引号。

今天我们又学

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 医药卫生 > 预防医学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1