为什么我的浮点运算坚持保持整数
Why do my floats insist on staying integers?
我正在读取几个整数,它们表示年份、儒略日、小时和分钟。我正试图将它们转换为分数天。
int YYYY, JJJ, HH, MM;
float datenumber = (YYYY*360.0f)+(JJJ*1.0f)+((HH*1.0f)+(MM/60.0f))/24.0f;
使用2001, 083, 22, 32
的值,我应该得到724043.939
的结果。相反,我得到了724044
。
我把所有的int都转换成浮点数。为什么它们保持为整数?
edit是的,我用cout显示输出。setprecision解决了问题,谢谢。
问题不在于你的数字或计算。这只是你显示它的方式。cout
已经决定6位数对你来说足够了。如果需要更多,请使用setprecision
。
std::cout << std::setprecision(10) << datenumber;
演示
您需要做两件事情:
- 将精度设置为最大值(
cout.setprecision(16)
) - 转换为
double
(double dateNumber
和YYYY*360.0
)
除非你有更多的代码在其他地方进行强制转换,否则你是在完成等式之后进行强制转换的,所以你会得到一个浮点值,但在强制转换之前使用等式中的int会去掉小数。
为什么不先将它们声明为浮动呢?
float YYYY, JJJ, HH, MM;
原因可能如下-1.可能是你打印错了。2.除以一个整数,请使用float。
示例不是除以200除以200.0
从您在Benjamin答案中提供的示例中的输入和输出值来看,我敢打赌问题只是浮点精度。仅仅因为你把某个东西声明为浮点,并不意味着它可以处理任何大小的数字。问题在于你的年份分量(1200*360=432000)比你的MM分量(5/60/24=.00347722)大得多。MM部分的小数部分被忽略了,因为浮点数没有那么准确。尝试将000001作为浮点值添加到123456789中,看看您的输出是什么
相关文章:
- 如何反转整数参数包
- enum是C++中的宏变量还是整数变量
- 努力将整数转换为链表。不知道我在这里做错了什么
- 整数不会重复超过随机数
- 在C++中手动调整数组大小
- 检查输入是否不是整数或数字
- C++使用整数的压缩数组初始化对象
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 将"打开的CV图像"中的"颜色"转换为整数格式
- 通过套接字[TCP]传输数据 如何在C / C ++中打包多个整数并使用send() recv()传输数据
- 如何只允许用户输入正整数
- 如何在c++中从文本文件中逐行读取整数
- C++:如何循环通过向量中的整数元素
- 我可以信任表示整数的浮点或双精度来保持精度吗
- 序列化,没有库的整数,得到奇怪的结果
- 在一定长度后从数组中打印时缺少整数
- std::当在256字节边界上写入整数时,流的奇怪行为
- 内联程序集printf将整数解释为地址
- 是否基于数组B整数打印数组A中的整数
- 为什么我的浮点运算坚持保持整数