题目描述:
把一个二进制数转化为十进制数。
输入格式:
第一行一个正整数 n( 1 ≤ n ≤ 30 ),表示二进制数的长度。
第二行一个二进制数。
输出格式:
输出一个整数,表示对应的十进制数。
输入样例:
5 10101
输出样例:
21
做题思路:先确定二进制数长度,注意输入完成后的回车要用getchar()函数给吃掉,之后初始化为0一个数,先让其乘二,再让二进制数的每一位与'0'做差并加入其中,最后输出。
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);//输入二进制数的长度
getchar();//输入长度后回车,此处回车为多余的,要用getchar()函数把回车吃掉
int a=0;//a初始化为0
for(a=0;n>0;n--){//二进制转十进制规则:先让初始值乘二,然后将二进制数每一位逐个处理
a*=2;//初始值乘二
a+=getchar()-'0';//处理对象默认为字符形式,用其与'0'做差,之后加到初始值里
}//逐位处理二进制数 则得出十进制数
printf("%d\n",a);//输出
return 0;
}