yueyufeng 发表于 2023-11-2 22:59:21

输入整数a,b,n ,计算a/b 的值,并输出其小数点后第n 位的数字是多少。

isdkz 发表于 2023-11-2 22:59:45

问题出在将浮点数转换为整数时,会将小数部分直接截断,导致结果错误。正确的方法是使用四舍五入的方式进行转换。

以下是修正后的代码:

#include <stdio.h>
#include <math.h>

int main() {
    int n, c, i, f;
    double e, a, b;
    scanf("%lf%lf%d", &a, &b, &n);
    e = a / b;
    for (i = 1; i <= n; i++) {
      e = e * 10;
    }
    c = (int)(e + 0.5);// 使用四舍五入的方式将浮点数转换为整数
    f = c % 10;
    printf("%d", f);
    return 0;
}


修正后的代码在将浮点数转换为整数时,使用了四舍五入的方式,即将浮点数加上0.5后再进行强制类型转换。这样可以保证小数部分正确地被转换为整数。

另外,为了保证输入的浮点数能正确被读取,需要使用 %lf 来读取double类型的变量。

Mike_python小 发表于 2023-11-2 23:00:19

问题分析:

根据你的描述,代码运行结果为-8,但是你期望的结果应该是一个非负数。这意味着代码存在一些问题。

根据代码逻辑,我们可以找到可能的问题:

1. 当输入的 a 大于等于 b 或者 n 小于等于 0 时,计算结果可能不准确。

2. 在计算小数位时,使用了循环将 e 乘以 10 的 n 次方。但是由于浮点数的精度限制,可能会导致结果出现误差。

3. 取整数部分时,使用了强制类型转换 (int)e,这可能会导致截断误差。

解决方案:

为了解决上述问题,可以采用以下修改方案:

1. 在进行计算之前,先判断输入的 a、b 和 n 是否符合要求,如果不符合要求,则输出错误信息并退出程序。

2. 使用整数类型进行计算,避免浮点数误差带来的问题。

3. 避免在每次循环中乘以 10,而是直接将 e 乘以 10 的 n 次方。

4. 使用取余操作获取小数位,避免通过强制类型转换造成的误差。

下面是修改后的代码:

++
#include <stdio.h>

int main()
{
    int a, b, n;
    scanf("%d%d%d", &a, &b, &n);

    // 判断输入是否合法
    if (a <= 0 || b <= 0 || a >= b || n <= 0)
    {
      printf("Error: Invalid input");
      return 0;
    }

    // 计算 a/b
    int quotient = a / b;
    int remainder = a % b;

    // 计算小数位
    for (int i = 0; i < n; i++)
    {
      remainder *= 10;
      quotient = remainder / b;
      remainder = remainder % b;
    }

    printf("%d", quotient);
    return 0;
}


希望这个解释对你有所帮助!如果还有其他问题,请随时提问。

球一个最佳答案谢谢啦!这对我非常重要!{:10_254:}{:10_254:}{:10_254:}
页: [1]
查看完整版本: 输入整数a,b,n ,计算a/b 的值,并输出其小数点后第n 位的数字是多少。