编写程序,取整数的二进制的低八位,并显示其对应的十进制数。如一个十进制整数2010,它的二进制是11111011010B,它的低八位是11011010B,转换为十进制是218。
程序运行结果如下:
输入:
2010
输出:
218
分析:
还是以十进制整数2010为例吧,它的二进制数为11111011010B,如果要取该数的低八位,需要用到逻辑与运算。我们知道,与运算的规则是 0&0=0 0&1=0 1&0=0 1&1=1,只有当相与的位都为1时结果才为1。所以要提取它的低八位,只需要该数与上1111111B(即十六进制的0xFF)。2010二进制为11位,与运算时11111111B位数不足,高位自动补零凑足11位,成为00011111111B
11111011010
与 00011111111
--------------------------
00011011010
结果为00011011010,即11011010B,即218
因此cout<<(i&0X0FF)<<endl; 的含义是:得到i&0xFF取低八位的结果,输出到屏幕,再输出一个回车
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int i;
cin>>i;
cout<<(i&0X0FF)<<endl;
return 0;
}