任务描述:
读入一个以1开头的二进制序列,请将其转换成十进制数输出。(用循环解决,不能使用数组和函数)
输入格式:
若干行,每行代表一组数据,是一串二进制数的1-0序列,最多不超过30位。所有数据只由1、0和回车组成,不包含任何其它空白字符。
输出格式:
依次输出每组数据转换成的十进制数,每个输出结果单独占一行。
输入样例:
1001
1000000000000000000000000000000
11110011
11110111
11111111
101
1
输出样列:
9
1073741824
243
247
255
5
1
#include<stdio.h>
int main(){
int n,sum=0,i,j,b=0,c=0;
int a[1000];
while(~scanf("%d",&n)){
for(i=0;n!=0;i++){
sum=n%10;
a[i]=sum;
n/=10;
c++;
}
for(j=0;j<c;j++){
b=b+a[j]*pow(2,j);
}
printf("%d\n",b);
}
return 0;
}