把一个二进制数转化为十进制数。
输入格式:
第一行一个正整数 n\ (1\le n\le 30)n (1≤n≤30),表示二进制数的长度。
第二行一个二进制数。
输出格式:
输出一个整数,表示对应的十进制数。
例如:
输入: 5
10101
输出: 21
#include<stdio.h>
#include<math.h>
int main(void)
{
int n,s=0;
char a[30];//定义a的范围
int i;
scanf("%d",&n);
a[i]=getchar();//将a[i]变为一个字符串
for(i=0;i<n;i++){
scanf("%c",&a[i]);
}
for(i=0;i<n;i++){//将二进制转化为十进制的公式
if(a[i]=='1'){
s+=pow(2,n-i-1);
}else{
s+=0;
}
}
printf("%d",s);
return 0;
}