把一个二进制数转化为十进制数。
输入格式
第一行一个正整数 n (1≤n≤30),表示二进制数的长度。
第二行一个二进制数。
输出格式
输出一个整数,表示对应的十进制数。
Sample Input
5 10101
Sample Output
21
解题思路:先输入一个n来表示二进制长度,然后运用getchar来接收n个数字,然后将第一个数乘与2*n-1,第二个数乘与2*n-2,以此类推,最后将每个数的乘积相加得到对应的十进制数。
#include <stdio.h>
#include <math.h>
int main() {
char a;
int n, i = 1, s = 0, k;
scanf("%d", &n);
getchar();
k = n;
while (i <= n) {
a = getchar() - '0';
s += a * pow(2, k - 1);
k--;
i++;
}
printf("%d\n", s);
return 0;
}