成语| 古诗大全| 扒知识| 扒知识繁体

当前位置:首页 > 数码科技

十进制和二进制的转换

Q1:c语言编写一个程序实现无符号十进制转换为二进制数

#include
intmain()
{
intn,i=0,cont=0;
charn2[100];
scanf("%d",&n);
while(n/2>0)
{
if(cont==4)
{
cont=0;
n2[i++]=,;
}
n2[i++]=n%2+0;
n=n/2;
cont++;
}
n2[i++]=n+0;
//-----------打印---------------------------
while(i-->0)
printf("%c",n2[i]);
}

Q2:怎么用scratch做十进制与与二进制之间的转换

用运算的模块。加上函数就可以了

学习更多好玩的数学知识。

Ww%w.BaZhIshI.cOM

Q4:PHP函数怎么把十进制转换为二进制

PHP decbin函数的作用是把十进制转换为二进制。

用法:

参数 描述

dec_number 必需。规定要转换的十进制数。

示例:

<?php
echodecbin("3");
echodecbin("1");
echodecbin("1587");
echodecbin("7");
?>

输出:

11、1、11000110011、111wwW.bAZhIS.Hi.cOm

Q5:求十进制转换十六位二进制,十进制0到 16

一)、数制
计算机中采用的是二进制,因为二进制具有运算简单,易实现且可靠,为逻辑设计提供了有利的途径、节省设备等优点,为了便于描述,又常用八、十六进制作为二进制的缩写。
一般计数都采用进位计数,其特点是:
(1)逢N进一,N是每种进位计数制表示一位数所需要的符号数目为基数。
(2)采用位置表示法,处在不同位置的数字所代表的值不同,而在固定位置上单位数字表示的值是确定的,这个固定位上的值称为权。
在计算机中:D7 D6 D5 D4 D3 D2 D1 D0 只有两种0和1、8 4 2 1、
二)、数制转换
不同进位计数制之间的转换原则:不同进位计数制之间的转换是根据两个有理数如相等,则两数的整数和分数部分一定分别相等的原则进行的。也就是说,若转换前两数相等,转换后仍必须相等。
有四进制
十进制:有10个基数:0 ~~ 9 ,逢十进一
二进制:有2 个基数:0 ~~ 1 ,逢二进一
八进制:有8个基数:0 ~~ 7 ,逢八进一
十六进制:有16个基数:0 ~~ 9,A,B,C,D,E,F (A=10,B=11,C=12,D=13,E=14,F=15) ,逢十六进一
1、数的进位记数法
N=a n-1*p n-1+a n-2*p n-2+…+a2*p2+a1*p1+a0*p0
2、十进制数与P进制数之间的转换
①十进制转换成二进制:十进制整数转换成二进制整数通常采用除2取余法,小数部分乘2取整法。例如,将(30)10转换成二进制数。
将(30)10转换成二进制数
230 ….0 ----最右位
2 15 ….1、2 7 ….1、2 3 ….1、1 ….1 ----最左位
∴ (30)10=(11110)2、将(30)10转换成八、十六进制数
830 ……6 ------最右位
3 ------最左位
∴ (30)10 =(36)8、
1630 …14(E)----最右位
1 ----最左位
∴ (30)10 =(1E)16、3、将P进制数转换为十进制数
把一个二进制转换成十进制采用方法:把这个二进制的最后一位乘上20,倒数第二位乘上21,……,一直到最高位乘上2n,然后将各项乘积相加的结果就它的十进制表达式。
把二进制11110转换为十进制
(11110)2=1*24+1*23+1*22+1*21+0*20=
=16+8+4+2+0
=(30)10、
把一个八进制转换成十进制采用方法:把这个八进制的最后一位乘上80,倒数第二位乘上81,……,一直到最高位乘上8n,然后将各项乘积相加的结果就它的十进制表达式。
把八进制36转换为十进制
(36)8=3*81+6*80=24+6=(30)10、把一个十六进制转换成十进制采用方法:把这个十六进制的最后一位乘上160,倒数第二位乘上161,……,一直到最高位乘上16n,然后将各项乘积相加的结果就它的十进制表达式。
把十六制1E转换为十进制
(1E)16=1*161+14*160=16+14=(30)10、3、二进制转换成八进制数
(1)二进制数转换成八进制数:对于整数,从低位到高位将二进制数的每三位分为一组,若不够三位时,在高位左面添0,补足三位,然后将每三位二进制数用一位八进制数替换,小数部分从小数点开始,自左向右每三位一组进行转换即可完成。例如:
将二进制数1101001转换成八进制数,则
(001 101 001)2、
( 1 5 1)8、( 1101001)2=(151)8、
(2)八进制数转换成二进制数:只要将每位八进制数用三位二进制数替换,即可完成转换,例如,把八进制数(643.503)8,转换成二进制数,则
(6 4 3 . 5 0 3)8、
(110 100 011 . 101 000 011)2、(643.503)8=(110100011.101000011)2、4、二进制与十六进制之间的转换
(1)二进制数转换成十六进制数:由于2的4次方=16,所以依照二进制与八进制的转换方法,将二进制数的每四位用一个十六进制数码来表示,整数部分以小数点为界点从右往左每四位一组转换,小数部分从小数点开始自左向右每四位一组进行转换。
(2)十六进制转换成二进制数
如将十六进制数转换成二进制数,只要将每一位十六进制数用四位相应的二进制数表示,即可完成转换。
例如:将(163.5B)16转换成二进制数,则
( 1 6 3 . 5 B )16、
(0001 0110 0011. 0101 1011 )2、(163.5B)16=(101100011.01011011)2

Q6:为什么除二求一法能够把十进制转换为二进制

众所周知,二进制的基数为2,我们十进制化二进制时所除的2就是它的基数。谈到它的原理,就不得不说说关于位权的概念。某进制计数制中各位数字符号所表示的数值表示该数字符号值乘一个与数字符号有关的常数,该常数称为 “位权 ” 。位权的大小是以基数为底,数字符号所处的位置的序号为指数的整数次幂。十进制数的百位、十位、个位、十分位的权分别是10的2次方、10的1次方、10的0次方,10的-1次方。二进制数就是2的n次幂。
按权展开求和正是非十进制化十进制的方法。
下面我们开讲原理,举个十进制整数转换为二进制整数的例子,假设十进制整数A化得的二进制数为edcba 的形式,那么用上面的方法按权展开, 得
A=a(2^0)+b(2^1)+c(2^2)+d(2^3)+e(2^4) (后面的和正是化十进制的过程)
假设该数未转化为二进制,除以基数2得
A/2=a(2^0)/2+b(2^1)/2+c(2^2)/2+d(2^3)/2+e(2^4)/2、注意:a除不开二,余下了!其他的绝对能除开,因为他们都包含2,而a乘的是1,他本是绝对不包含因数2,只能余下。
商得:
(2^0)+c(2^1)+d(2^2)+e(2^3),再除以基数2余下了b,以此类推。
当这个数不能再被2除时,先余掉的a位数在原数低,而后来的余数数位高,所以要把所有的余数反过来写。正好是edcba

Q7:十进制转换成无符号二进制整数和二进制数的区别?

无符号二进制整数无法表示负十进制数
十进制转换成二进制后,如果是负数会转换成补码表示形式,然后按照无符号二进制数来理解,就是题目意思了
比如:5表示成4位二进制数是0101B,有符号无符号都得到数值5;
-5表示成4位二进制数是求补码过程:5=0101B,取反=1010B,加1=1011B,因此-5表示成有符号4位二进制是1011B,1011B当成无符号二进制数是11D

猜你喜欢

更多