C++中几种将整数转换成二进制输出的方法总结

 对于二进制一直不是很有感觉,看到了一篇比较好的博文,将二进制输出的算法总结的差不多了,

一起学习一下,原文网址https://www.jb51.net/article/92462.htm


看《编程之美》第二节的时候,它是定义的一个整型,然后取位。但是他的那个或运算符号好像写错了,写成了异或符号“^”,应该是“|”。我就突然对二进制的输出感兴趣了。想知道怎样输出二进制。我们知道C++输出十六进制是cout〈〈hex〈〈 a;而八进制是cout〈〈 ocx〈〈 a;二进制则没有默认的输出格式,需要自己写函数进行转换,于是上网搜索了一下。网上思路真是广泛啊。

下面列出一些方法。  

#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; 
}

//运行后的结果如下:
BinaryRecursion(c):10000010111 
BinaryVector(c):10000010111 
Binarycout(c):00000000000000000000010000010111 
BinaryBitset(c):00000000000000000000010000010111 
BinaryChar(c):10000010111 
Press any key to continue

  这几种算法还可以用来统计二进制某字符的数目。

猜你喜欢

转载自blog.csdn.net/sodacoco/article/details/81624915
今日推荐