题解 | #10进制 VS 2进制#

10进制 VS 2进制

http://www.nowcoder.com/practice/fd972d5d5cf04dd4bb4e5f027d4fc11e

从二进制转十进制,只需从低位到高位依次加上各数位的值,并不断乘以2就能实现转换。由于是对字符串进行操作,因此需要重新编写两个函数来实现字符串对应的乘法和加法操作。

对于乘法运算,函数的做法是将字符串从低位到高位逐位乘以乘数。如果某位乘以乘数后超过了10,那就让其对10取模,并保留进位。之后,将进位和高一位一起进行处理,这样就可以模拟字符串乘法的效果,但有可能出现最高位进位的情况,这时候只需在字符串首部加上1即可。

#include <iostream>
#include <string>
#include <stack>

using namespace std;

string Divide(string s, int x) {
    int remainder = 0;
    for (int i = 0; i < s.size(); i++) {
        int cur = remainder * 10 + s[i] - '0';
        s[i] = cur / x + '0';
        remainder = cur % x;
    }
    int pos = 0;
    while (s[pos] == '0') {
        pos++;
    }
    return s.substr(pos);
}

string convertFunc1(string s, int x) {
    stack<int> sck;
    while (s.size() != 0) {
        int bit = (s[s.size()-1] - '0') % 2;
        sck.push(bit);
        s = Divide(s, x);
    }
    string res;
    while (!sck.empty()) {
        res.push_back(sck.top()+'0');
        sck.pop();
    }
    return res;
}

string Multiple(string str, int x) {    //字符串乘法
    int carry = 0;     //进位
    for (int i = str.size() - 1; i >= 0; i--) {
        int cur = x * (str[i] - '0') + carry;
        str[i] = cur % 10 + '0';
        carry = cur / 10;
    }
    if (carry != 0) {
        str = "1" + str;
    }
    return str;
}

string Add(string str, int x) {      //字符串加法
    int carry = x;
    for (int i = str.size() - 1; i >= 0; i--) {
        int cur = (str[i] - '0') + carry;
        str[i] = cur % 10 + '0';
        carry = cur / 10;
    }
    if (carry != 0) {
        str = "1" + str;
    }
    return str;
}

string convertFunc2(string s, int x) {
    string ans = "0";
    for (int i = s.size() - 1; i >= 0; i--) {   //从最低二进制位开始
        ans = Multiple(ans, x);
        ans = Add(ans, s[i]-'0');
    }
    return ans;
}


int main()
{
    string s;
    while (cin >> s) {
        cout << convertFunc2(convertFunc1(s, 2), 2);
    }
    return 0;
}

全部评论

相关推荐

10-29 16:42
门头沟学院 Java
1.今天什么国标的公司打电话约面试,还得准备ppt,好麻烦,网上查薪资一般,打算拒了,不面了2.字节又复活了,什么安全开发,也不知道怎么样,面一面试试吧,还是挺想去字节的,但好难,随缘吧所以今天没面试
嵌入式的小白:面试前可以好好准备下 1.看看你投递的岗位的岗位描述,分析下是哪个业务线,同使要罗列他们描述中提到的技术点 2.根据1中的两点准备 3.岗位描述中应该还有语言要求,这个刷刷八股,要是对自己语言能力很有把握,那就不用看这点了 4.找下你简历中项目部分,看有没有和岗位描述中技术点重合的,这种在面试提到项目时,是高概率问题 好好准备,祝你面试顺利
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务