我们想一想咋实现这个算法:
input:
输入一个二进制字符串,不能是其他类型的字符,只能为0和1,所以在这里要做出限制。
略去非0和1的字符后,把二进制字符串逐个输入进行计算。
二进制转化为十进制方法为:例子:110 0*2+1*2*2+1*2*2*2
output:输出一个十进制数即可
如下为具体的c++代码:
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int dec = 0;
char ch;
do {
(ch); //只可以输入一个字符,但是你输入一串0,1字符也可以因为它一次只会读取一个字符
} while (ch != '0'&&ch != '1'); //这里其实是对非0,1字符进行过滤
do {
dec += ch - '0';//一开始看到这里很疑惑后面想清楚了其实就是c++认识的数据类型的数都是先将其转化为ASCII码值后才进行运算的。
(ch);
if (ch == '0' || ch == '1')
dec *= 2;
} while (ch == '0' || ch == '1');
cout << dec << endl;
system("pause");
return 0;
}
要提醒的是比如说你要计算10011的值你不能顺序输入你应该是输入11001把其反过来输入,这个是先处理低位数的