fanglei369
fanglei369
2018-09-19 08:49

请高手帮忙指点一下这个C++程序为什么和我要的结果不一样?

  • c++
  • 指针
  • 二进制

#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的二进制位码,但我的答案和正确答案差距很大。我自己笔算可以得到正确答案,请问我的程序哪个地方出了问题?当我把第二个循环去掉的时候,运行后只有我的答案的前部分,是因为指针的位数不够导致的,还是我循环的方式出错了?

这个问题只用循环的方式解,我是初学者在网上查到的什么数组那样的麻烦就别回复了,我现在只能看懂循环的部分。

  • 点赞
  • 回答
  • 收藏
  • 复制链接分享

2条回答