#include
using namespace std;
int main()
{
double a=19.2;
int* pa = reinterpret_cast(&a);
for(int i=31; i>=0; i--)
cout<<(*pa>>i & 1)<<(i==31||i==20 ? ",":"");
for(int j=31; j>=0; j--)
cout<<((*pa+1)>>j & 1);
cout<<"\n";
}
正确答案:0,10000000011,0011001100110011001100110011001100110011001100110011
我的答案:0,01100110011,0011001100110011001100110011001100110011001100110100
我需要用这样循环的形式得到double类型19.2的二进制位码,但我的答案和正确答案差距很大。我自己笔算可以得到正确答案,请问我的程序哪个地方出了问题?当我把第二个循环去掉的时候,运行后只有我的答案的前部分,是因为指针的位数不够导致的,还是我循环的方式出错了?
这个问题只用循环的方式解,我是初学者在网上查到的什么数组那样的麻烦就别回复了,我现在只能看懂循环的部分。
吃鸡游戏
www说
相关分类