看《编程之美》第二节的时候,它是定义的一个整型,然后取位。但是他的那个或运算符号好像写错了,写成了异或符号“^”,应该是“|”。我就突然对二进制的输出感兴趣了。想知道怎样输出二进制。我们知道C++输出十六进制是cout〈〈hex〈〈 a;而八进制是cout〈〈 ocx〈〈 a;二进制则没有默认的输出格式,需要自己写函数进行转换,于是上网搜索了一下。网上思路真是广泛啊。
下面列出一些方法。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
#include 〈iostream〉 #include 〈list〉 #include 〈bitset〉 using namespace std; //递归输出二进制函数 void BinaryRecursion( int n) { int a; a=n%2; n=n〉〉1; if (n==0) ; else BinaryRecursion(n); cout〈〈a; } //使用容器转换二进制 void BinaryVector( int n) { int temp; temp=n; list〈 int 〉 L; while (temp!=0) { L.push_front(temp%2); temp=temp〉〉1; } for (list〈 int 〉::iterator iter=L.begin();iter!=L.end();iter++ ) cout〈〈*iter; cout〈〈endl; } //一般方法,32位,逐步与1做与运算。 void Binarycout( int n) { for ( int i=31;i〉=0;i--) { cout〈〈((n〉〉i)&1); } cout〈〈endl; } //使用bitset转换二进制 void BinaryBitset( int n) { cout〈〈bitset〈 sizeof ( int )*8〉(n)〈〈endl; } int main() { int a=1045,b=2; int c; c=a+b; cout〈〈 "BinaryRecursion(c):" ; BinaryRecursion(c); cout〈 BinaryVector(c); cout〈〈 "Binarycout(c):" ; Binarycout(c); cout〈〈 "BinaryBitset(c):" ; BinaryBitset(c); cout〈〈 "BinaryChar(c):" ; BinaryChar(c); //cout〈 return 0; } |
运行后的结果如下:
1
2
3
4
5
6
|
BinaryRecursion(c):10000010111 BinaryVector(c):10000010111 Binarycout(c):00000000000000000000010000010111 BinaryBitset(c):00000000000000000000010000010111 BinaryChar(c):10000010111 Press any key to continue |
从中可以看出,有两种运算会得出32位的结果,不太好。我对C++还不是很精通,所以这个效率还不是很清楚哪个个好。
我觉得用容器的可能会好些吧。如果是C,就用字符转换函数,或者直接除后和1做与运算。
以上这篇C++中几种将整数转换成二进制输出的方法总结就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。