描述
大家都知道,数据在计算机里中存储是以二进制的形式存储的。 有一天,小明学了C语言之后,他想知道一个类型为unsigned int 类型的数字,存储在计算机中的二进制串是什么样子的。 你能帮帮小明吗?并且,小明不想要二进制串中前面的没有意义的0串,即要去掉前导0。
输入描述:
多行,每一行表示要求的数字
输出描述:
输出共T行。每行输出求得的二进制串。
输入:
23
535
2624
56275
989835
输出:
10111
1000010111
101001000000
1101101111010011
11110001101010001011
思路:十进制数对2取模,整除2,逆序输出
#include<bits/stdc++.h>
using namespace std;
int main()
{
unsigned int n;
while(cin>>n){
stack<int>binary;
while(n){
binary.push(n%2);
n/=2;
}
while(binary.size()){
cout<<binary.top();
binary.pop();
}
cout<<endl;
}
return 0;
}