首页 > 其他 > 详细

3.5c

时间:2019-07-24 00:34:47      阅读:85      评论:0      收藏:0      [点我收藏+]
/*题目描述
将一个长度最多为30位数字的十进制非负整数转换为二进制数输出。

输入
多组数据,每行为一个长度不超过30位的十进制非负整数。
(注意是10进制数字的个数可能有30个,而非30bits的整数)

输出
每行输出对应的二进制数。

样例输入
985
211
1126
样例输出
1111011001
11010011
10001100110
*/

#include <iostream>
#include <string>
#include <algorithm>
using namespace std;

string change(string str)
{
    string ans = "";
    int len = str.size();
    for(int i=0; i<len; )
    {
        int k=0;
        for(int j=i; j<len; j++)
        {
            int temp = (k*10 + str[j] - 0)%2;
            str[j] = (k*10 + str[j] - 0)/2 + 0;
            k = temp;
        }
        ans += (k + 0);
        while(str[i]==0) i++;
    }
    return ans;
}

int main()
{
    string num;
    while(cin >> num)
    {
        string ans = change(num);
        reverse(ans.begin(),ans.end());
        cout << ans << endl;
    }
    return 0;
}

 

3.5c

原文:https://www.cnblogs.com/yeoreum/p/11235190.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!