把一个二进制数转化为十进制数。
输入格式
第一行一个正整数 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];
int i;
scanf("%d",&n);//输入一个整数;
getchar();//输入一个字符;
for(i=0;i<n;i++)//历遍数组;
{
scanf("%c",&a[i]);//输入数组;
}
for(i=0;i<n;i++)//历遍数组;
{
if(a[i]=='1')//逐一判断字符是否为数字'1';
{
s=s+pow(2,n-i-1);//符合条件的数就定义;
}
else
{
s=s+0;
}
}
printf("%d",s);
return 0;
}