c语言问题关于2进制转化为10进制
题目描述:题目很简单,就是把一个二进制数转换为十进制数,然后输出。输入描述:多组测试数据,第一行一个正整数n(n<=1000),表示后面有n组测试数据,每组一行。接下来有...
题目描述:题目很简单,就是把一个二进制数转换为十进制数,然后输出。
输入描述:多组测试数据,第一行一个正整数 n (n<=1000),表示后面有 n 组测试数据,每组一行。
接下来有 n 行,每行为一个不超过32位的二进制数。
我的代码
#include<stdio.h>
#include<math.h>
int main()
{
int a,two,ten,b,c;
c=0;
ten=0;
scanf("%d",&a);
while(a)
{
scanf("%d",&two);
for(;two!=0;)
{
b=two%10;
ten=ten+b*pow(2,c);
two=two/10;
c++;
}
printf("%d\n",ten);
c=0;
ten=0;
a--;
}
}
为什么我输入比较小的2进制数 输出的10进制是对的 二进制输入一大10进制答案就错了 展开
输入描述:多组测试数据,第一行一个正整数 n (n<=1000),表示后面有 n 组测试数据,每组一行。
接下来有 n 行,每行为一个不超过32位的二进制数。
我的代码
#include<stdio.h>
#include<math.h>
int main()
{
int a,two,ten,b,c;
c=0;
ten=0;
scanf("%d",&a);
while(a)
{
scanf("%d",&two);
for(;two!=0;)
{
b=two%10;
ten=ten+b*pow(2,c);
two=two/10;
c++;
}
printf("%d\n",ten);
c=0;
ten=0;
a--;
}
}
为什么我输入比较小的2进制数 输出的10进制是对的 二进制输入一大10进制答案就错了 展开
展开全部
题目要求二进制数不超过32位,显然应该用字符串读入和存储,而不是用int整型存储,因为int型最多只能表示9位十进制数。但32位二进制对应的数值仍然在unsigned int型范围内,所以转换后的结果仍然可以用unsigned int型存储。
#include<stdio.h>
#include<string.h>
int main()
{
int i,j,n;
unsigned int dec;
char bin_str[33];
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%s",bin_str);
dec=0;
for(j=0;j<strlen(bin_str);j++)
{
dec<<=1;
dec|=bin_str[j]-'0';
}
printf("%u\n",dec);
}
return 0;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询