输入一个二进制表示的正整数,转换成十进制输出

2023-10-31

我们想一想咋实现这个算法:

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 {
        cin.get(ch); //只可以输入一个字符,但是你输入一串0,1字符也可以因为它一次只会读取一个字符
    } while (ch != '0'&&ch != '1'); //这里其实是对非0,1字符进行过滤
    do {
        dec += ch - '0';//一开始看到这里很疑惑后面想清楚了其实就是c++认识的数据类型的数都是先将其转化为ASCII码值后才进行运算的。
        cin.get(ch);
        if (ch == '0' || ch == '1')
            dec *= 2;

    } while (ch == '0' || ch == '1');
    cout << dec << endl;
        

    system("pause");
    return 0;
}

要提醒的是比如说你要计算10011的值你不能顺序输入你应该是输入11001把其反过来输入,这个是先处理低位数的

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

输入一个二进制表示的正整数,转换成十进制输出 的相关文章

随机推荐