怎样用C语言将二进制数转换成十进制
发布网友
发布时间:2022-04-21 19:55
我来回答
共5个回答
热心网友
时间:2022-06-18 21:50
将二进制转成十进制,按权值展开求和即可。
可以通过以下代码解决:
#include <stdio.h>
#include <stdlib.h>
int main()
{
char a[17];
gets(a);
int len,i,sum=0,m,j;
len=strlen(a);
if(len<=16)
{
for(i=0;i<len;i++)
{
m=1;
if(a[i]=='1')
{
for(j=1;j<=len-i-1;j++)
m*=2;
sum+=m;
}
}
printf("%d",sum);
}
return 0;
}
扩展资料:
我们常用的进制包括:二进制、八进制、十进制与十六进制,它们之间区别在于数运算时是逢几进一位。比如二进制是逢2进一位,十进制也就是我们常用的0-9是逢10进一位。
十进制转二进制:十进制数除2取余法,即十进制数除2,余数为权位上的数,得到的商值继续除2,依此步骤继续向下运算直到商为0为止。
八进制转二进制:八进制数通过除2取余法,得到二进制数,对每个八进制为3个二进制,不足时在最左边补零。
十六进制转二进制:十六进制数通过除2取余法,得到二进制数,对每个十六进制为4个二进制,不足时在最左边补零。
负数的进制转换稍微有些不同。
先把负数写为其补码形式(在此不议),然后再根据二进制转换其它进制的方法进行。
例:要求把-9转换为八进制形式。则有:
-9的补码为1111 1111 1111 0111。从后往前三位一划,不足三位的加0
111---->7
110---->6
111---->7
111---->7
111---->7
001---->1
然后我们将结果按从下往上的顺序书写就是:177767,那么177767就是十进制数-9的八进制形式。
其实转化成任意进制都是一样的。
参考资料:
二进制——百度百科
十进制——百度百科
热心网友
时间:2022-06-18 21:50
将二进制转成十进制,按权值展开求和即可。
可以通过以下代码解决:
#include
#include
int
main()
{
char
a[17];
gets(a);
int
len,i,sum=0,m,j;
len=strlen(a);
if(len<=16)
{
for(i=0;i
扩展资料:
我们常用的进制包括:二进制、八进制、十进制与十六进制,它们之间区别在于数运算时是逢几进一位。比如二进制是逢2进一位,十进制也就是我们常用的0-9是逢10进一位。
十进制转二进制:十进制数除2取余法,即十进制数除2,余数为权位上的数,得到的商值继续除2,依此步骤继续向下运算直到商为0为止。
八进制转二进制:八进制数通过除2取余法,得到二进制数,对每个八进制为3个二进制,不足时在最左边补零。
十六进制转二进制:十六进制数通过除2取余法,得到二进制数,对每个十六进制为4个二进制,不足时在最左边补零。
负数的进制转换稍微有些不同。
先把负数写为其补码形式(在此不议),然后再根据二进制转换其它进制的方法进行。
例:要求把-9转换为八进制形式。则有:
-9的补码为1111
1111
1111
0111。从后往前三位一划,不足三位的加0
111---->7
110---->6
111---->7
111---->7
111---->7
001---->1
然后我们将结果按从下往上的顺序书写就是:177767,那么177767就是十进制数-9的八进制形式。
其实转化成任意进制都是一样的。
参考资料:
二进制——百度百科
十进制——百度百科
热心网友
时间:2022-06-18 21:51
二进制转十进制
从最后一位开始算,依次列为第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.
一、二进制数转换成十进制数
由二进制数转换成十进制数的基本做法是,把二进制数首先写成加权系数展开式,然后按十进制加法规则求和。这种做法称为"按权相加"法。
这是一个二进制转十进制的C语言函数例子,希望对你有帮助:
void two_ten()
{
long num;
int b,TheTen=0,Total=0;
printf("\n请输入一个二进制数(只包含0或1):");
scanf("%ld",&num);
while(num)
{
b=num-(int)(num/10)*10;
TheTen+=b*pow(2,Total);;
Total++;
num=(int)(num/10);
}
printf("转换为十进制:"); //打印
printf("%d",TheTen);
printf("\n");
}
热心网友
时间:2022-06-18 21:52
#include
#include
viod
main()
{
int
i,n,k=1,a[50];
//50个二进制位够大的吧
printf("enter
n:");
scanf("%d",&n);
if(n<=0)
exit(0);
//小于0的不要,等于0也没有必要了
a[0]=n%2;
do
{
n=n/2;
i=n%2;
a[k++]=i;
}while(n!=0);
for(i=49;a[i]==0;i--)
;
//找到二进制开始的地方,也就是最后一个余数在数组中的位置
for(;i>-1;i--)
printf("%d",a[i]);
}
热心网友
时间:2022-06-18 21:52
#include "stdafx.h"
int main()
{
int binary;
int temp;
int sum = 0;
int n = 1;
printf("Please input the binary number:");
scanf("%d",&binary);
for(;binary != 0;binary = binary/10)
{
temp = binary%10; //得到个位数、十位数、百位数.....
sum += temp * n;
n = n * 2;
}
printf("Decimalism is %d\n",sum);
return 0;
}