求大牛帮忙解答?

kafeimao 2014-01-19 04:25:23
Write a program which does the following: Given a real decimal number input, take the number apart and convert it to a 32 bit floating point number represented as a binary string (that is, a string of 1s and 0s). You may use both numeric and string manipulations to build the binary number from its parts (sign, mantissa, and exponent), but please return a string. The goal is to explore how an arbitrary decimal number is disassembled and represented as a 32 bit floating point number.
...全文
112 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
bobo_包子 2014-01-19
  • 打赏
  • 举报
回复
float f = 0;
	cout << "input a number:" << endl;
	cin >> f;

	unsigned char flag = 1 << 7;
	char *pf = (char *)&f;
	int i = 0, j = 0;
	while(i++ < sizeof(f))
	{
		while(j++ < 8)
		{
			if((*pf & flag) == flag)
				cout << "1";
			else
				cout << "0";

			flag >>= 1;
		}
		flag = 1 << 7;
		j = 0;
		pf += 1;
	}

	getchar();
	getchar();
	return 0;

65,186

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧