解题思路:
1.先直接输入n,如果n=0了,直接输出0-->0,如果n>0,进行进制转换运算,如果n<0,先输出一个负号(-)然后n取反,再进行进制转换运算。
2.期间利用了vector,不过感觉在这里用起来反而更加麻烦。
for(vector<int>::reverse_iterator it=ss.rbegin(); it!=ss.rend(); it++) {
cout<<*it;
}
这一句话主要是逆序迭代器,然后利用迭代器来进行输出,指针就是间接指向最末端的值,再依次后移而已(后移是往前面取值,因为reverse_iterator,逆序迭代器了,当然可以不逆序迭代器直接用it--而不是it++的方式进行前移)
3.ss.push_back(n%2);是输入,也可以直接ss[i]=n%2的方式进行输入
参考代码:
#include<bits/stdc++.h> using namespace std; int main() { int n; while(cin>>n) { cout<<n<<"-->"; vector<int> ss; if(n==0) cout<<'0'<<endl; else if(n>0) { bug: while(n>0) { ss.push_back(n%2); n=n/2; } for(vector<int>::reverse_iterator it=ss.rbegin(); it!=ss.rend(); it++) { cout<<*it; } cout<<endl; } else { n=-n; cout<<'-'; goto bug; } } return 0; }
0.0分
0 人评分
WU-输入输出格式练习 (C++代码)浏览:1082 |
最小公倍数 (C语言代码)浏览:1029 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:902 |
Minesweeper (C语言描述,蓝桥杯)浏览:1127 |
简单的a+b (C语言代码)浏览:419 |
核桃的数量 (C语言代码)浏览:872 |
演讲大赛评分 (C语言代码)浏览:1640 |
C二级辅导-温度转换 (C语言代码)浏览:732 |
蛇行矩阵 (C语言代码)浏览:507 |
IP判断 (C语言代码)浏览:539 |