把一个二进制数转化为十进制数。
输入格式
第一行一个正整数 n (1≤n≤30) 表示二进制数的长度。
第二行一个二进制数。
输出格式
输出一个整数,表示对应的十进制数。
例:输入
5
10101
输出:
21
整体思路:
利用for语句进行二进制转换为十进制
二进制10101转为十进制,因为以0开头,所以这是正整数,计算如下所示:
#include#include #include int main() { int i, d, a, b, sum = 0; char str[30];//字符数组string,长度30 scanf("%d", &d);//输入二进制长度 scanf("%s", str);//输入二进制数 for (i = 0; i < d; i++) {//二进制转为十进制要从右到左用二进制的每个数去乘以2的相应次方求和 a = str[i] - 48; b = pow(2, d - 1 - i);//2的次方 sum += a * b;//十进制要从右到左用二进制的每个数去乘以2的相应次方相加 } printf("%dn", sum);//输出十进制整数 return 0; }



