PS: 程序为cpp代码,最重要理解操做。spa
方法一: n进制方法,也能够解决转换为其余进制问题。blog
/*将整数转化为二进制的string 输出*/
string convert(int num) {
string res = "";
if (num == 0) return "0";
int val = num;
num = abs(num);
while (num) {
res.insert(0, to_string(num % 2));
num /= 2;
}
if (val < 0) res.insert(0, "-");
return res;
}
方法二: 使用容器转换递归
/*使用vector进行存储*/
vector<int> convert(int n) {
int temp;
temp = n;
vector<int> res;
while (temp !=0) {
res.push_back(temp % 2);
temp = temp >> 1;
}
return res;
}
方法三: 递归输出转换二进制string
/*递归转换二进制*/
void convert(int n) {
int a;
a = n % 2;
n = n >> 1;
if (n == 0)
return;
else
convert(n);
cout << a; // 01逐个输出
}
方法四:位运算转换二进制it
/*位运算转换二进制*/
void convert(int n) {
for (int = 31; i >= 0; i--) { // 32位,逐步与1作与运算
cout << (n >> i) & 1;
}
}
方法五:使用bitset 转换二进制class
void convert(int n) {
cout << bitset<sizeof(int) * 8>(n) << endl;
}