码迷,mamicode.com
首页 > 其他好文 > 详细

十进制转二进制

时间:2019-01-09 23:35:13      阅读:320      评论:0      收藏:0      [点我收藏+]

标签:rem   signed   name   code   bin   main   ==   namespace   std   

十进制转二进制

思路:所谓的“除二取余”,一个数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;
}

十进制转二进制

标签:rem   signed   name   code   bin   main   ==   namespace   std   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!