加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

3.5c

发布时间:2020-12-16 10:49:13 所属栏目:百科 来源:网络整理
导读:/* 题目描述将一个长度最多为30位数字的十进制非负整数转换为二进制数输出。输入多组数据,每行为一个长度不超过30位的十进制非负整数。(注意是10进制数字的个数可能有30个,而非30bits的整数)输出每行输出对应的二进制数。样例输入9852111126样例输出1111
/*题目描述
将一个长度最多为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;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读