首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >c++11双精度

c++11双精度
EN

Stack Overflow用户
提问于 2022-06-06 07:27:53
回答 1查看 109关注 0票数 0

执行下列计算:

代码语言:javascript
复制
double result = 58/10;

结果: 5.7999999999999998

我知道c++会在进一步的计算或打印中对其进行舍入,但我需要将输出与不发生舍入的地方进行比较,因此不能进行舍入,因为这可能只会导致输出中其他地方的差异。

有没有办法提高这类计算的精度,并得到58/10的结果5.8?

EN

回答 1

Stack Overflow用户

发布于 2022-06-06 07:34:56

5.8不能完全用浮点表示。如果您在小数点之后使用2位精度,例如,如果需要存储货币值,则将其存储为" 580“(例如,580美分),并在打印时执行自己的格式设置。

代码语言:javascript
复制
printf("%d.%02d", n / 100, n % 100);

或者,将十进制存储为一个分数:

代码语言:javascript
复制
struct Fraction {
  int numerator;
  int denominator;
};

int main() {
  Fraction f(29, 5);
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72514373

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档