gpt4 book ai didi

c++ - 与 int 相比,double 数据类型如何在 C++ 中大量改变答案?

转载 作者:行者123 更新时间:2023-12-01 14:36:35 25 4
gpt4 key购买 nike

我正在解决一个问题“计算阶乘中的位数”,并将答案存储在 int 和 double 两种数据类型中。两种数据类型的答案不同,存储在 double 中的答案最终是正确的。这是怎么回事?

代码如下:

        int n;
cin>>n;
double ans;
int ans_int;
double digits = 0;
int digit_int = 0;
for (int i = 1; i<=n; i++) {
digits += log10(i);
digit_int += log10(i);
}

ans = floor(digits)+1;

ans_int = floor(digit_int)+1; // This gives wrong answer.

cout<<ans<<endl;

如果在上面的代码中,我将数字设为 int,而不是 double,我得到的答案是 1 位,在 5 中!而不是 3,在其他情况下类似。

最佳答案

将 double 转换为 int 首先将其向下舍入为最接近的整数。所以如果你把 x ≤ 10 ≤ 99 的 log10(x) 相加,对数总是在 1 和 2 之间,但转换为 int 只会加 1,而不是正确的值。

关于c++ - 与 int 相比,double 数据类型如何在 C++ 中大量改变答案?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63260896/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com