校OJ的水题,但是可以创新一下用位运算来计算
但是要注意 C语言中的数字常数默认类型为int 位移过程中可能出现溢出
Description
给出一个二进制的非负整数x,x<232,把它转换成十进制数输出。
Input 输入为多行,每行一个二进制非负整数x。
Output 每行输出x对应的十进制数值。
Sample Input
0 1 01 10 11 100001 1111111111111111
Sample Output
0 1 1 2 3 33 65535
HINT
注意数据范围!!!
1 #include "stdio.h"
2 #include "string.h"
3 const int maxn = 100000;
4 int main(int argc, char const *argv[])
5 {
6 char indata[maxn];
7 memset(indata,0,sizeof(indata));
8 while(scanf("%s",indata)!=EOF)
9 {
10 int n = strlen(indata);
11 unsigned long long sum = 0;
12 for(int i=n-1;i>=0;i--)
13 {
14 unsigned long long k = indata[i]-'0';
15 sum += (k<<(n-i-1));
16 }
17 printf("%llu\n",sum );
18 }
19 return 0;
20 }
浙公网安备 33010602011771号