题目:编写并测试一个函数printBianry(),这个函数按照你所采用的C++版本中存储int型值所用的二进制位的个数,以二进制形式显示int型值。例如,如果int型使用32位,则函数值对17显示为:00000000000000000000000000010001。
分析:这个题用位运算做最简单,初始化一个unsigned int型变量mask,它的值的为INT_MIN(在climits里的宏定义),二进制表示为1后面跟着全是0,一共32位,即10000000000000000000000000000000。对于一个从1开始,到二进制位的个数为止的计数器,做以下工作:
(1)如果给定整数与mask按位与(&)的结果非0,显示'1',否则显示'0';
(2)将mask中的位右移一位;
C++代码如下:
#include <iostream>
#include <climits>
using namespace std;
void printBinary(int val);
int main()
{
int val;
cin>>val;
printBinary(val);
return 0;
}
void printBinary(int val)
{
unsigned int mask = INT_MIN;
for(unsigned int i=0 ; i < sizeof(int)*8 ; i++)
{
cout<<((mask & val) != 0 ? '1' : '0');
mask = mask >> 1;
}
}

本文介绍如何使用C++编程语言实现一个函数,该函数可以以二进制形式打印int类型的数值,通过位运算操作来实现转换。
1018

被折叠的 条评论
为什么被折叠?



