- 思路:除2取余,用栈逆序输出余数
- 由于数据较大,要自定义字符串除法
#include<iostream>
#include<stack>
#include<string>
using namespace std;
stack<int>bin; //余数栈
string s;
int getdiv(string &s){//返回除以2的余数
int k=0;
int answer=(s[s.size()-1]-'0')%2;
for(int i=0;i<s.size();i++){//字符串除以2
int cur=s[i]-'0'+k*10;//本位的数+上一位的余数*10
s[i]=cur/2+'0';
k=cur%2;
}
int pos=0;
while(s[pos]=='0')pos++;
s=s.substr(pos);//去掉前面多余的0
return answer;
}
int main(){
int t;
while(cin>>s){
while(s.size()!=0){
bin.push(getdiv(s));//余数入栈
}
while(bin.size()!=0){//输出
printf("%d",bin.top());
bin.pop();
}
printf("\n");
}
return 0;
}