首页 > 其他 > 详细

十进制转二进制

时间:2019-01-09 23:25:41      阅读:250      评论:0      收藏:0      [点我收藏+]

十进制转二进制

思路:所谓的“除二取余”,一个数n先取余数,所得余数为最低位,然后除以二再取余数,所得余数为次低位,以此类推直到n == 1,再加一个1为最高位即可

#include <iostream>
#include <string>

using namespace std;

void dec_to_bin(unsigned int n){
    if(n == 0){
        cout << 0 << endl;
        return;
    }
    int remainder;
    string s;
    while(n != 1){
        remainder = n % 2;
        n = n / 2;
        if(remainder == 0)
            s = s + ‘0‘;
        else s = s + ‘1‘;
    }
    s = s + ‘1‘;
    for(int i = s.size() - 1; i >= 0; i--){
        cout << s[i];
    }
    cout << endl;
}

int main(){
    unsigned int n;
    while(cin >> n){
        dec_to_bin(n);
    }
    return 0;
}

十进制转二进制

原文:https://www.cnblogs.com/zhuobo/p/10247360.html

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