BUPT-二进制数

题目链接

https://www.nowcoder.com/practice/103dd589fed14457a673c613d8de3841?tpId=67&tqId=29634&tPage=1&ru=/kaoyan/retest/1005&qru=/ta/bupt-kaoyan/question-ranking

题目描述

大家都知道,数据在计算机里中存储是以二进制的形式存储的。 有一天,小明学了C语言之后,他想知道一个类型为unsigned int 类型的数字,存储在计算机中的二进制串是什么样子的。 你能帮帮小明吗?并且,小明不想要二进制串中前面的没有意义的0串,即要去掉前导0。

输入描述:

每行有一个数字n(0<=n<=10^8),表示要求的二进制串。

输出描述:

输出共T行。每行输出求得的二进制串。
示例1

输入

复制
23

输出

复制
10111

题解:

#include <iostream>
using namespace std;
void getbin(int num){
    int a[50]; 
    int length = 0, i = 0;
    for (i = 0; i < 50; i++){
    	if(num < 1) break;
        a[i] = num % 2;
        num = num / 2;
        length++;
    }
    for(i = length - 1; i >= 0; i--){
        cout << a[i];
    }
}
int main(){
    int num;
    while(cin >> num){
        getbin(num); 
    } 
    return 0;   
}  

猜你喜欢

转载自blog.csdn.net/reigns_/article/details/80985457