鱼C论坛

 找回密码
 立即注册
查看: 1823|回复: 3

[已解决]答案错误是什么原因啊

[复制链接]
发表于 2023-10-11 16:25:42 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
平台错误提示是
[Test #1 0.in]
[Test 0.out] Wrong answer on line 17
Yours:
-501043139481094097
Correct:
378011820620313
题目是
输入一个正整数n
,计算1!+2!+⋯+n!
输入描述
多组输入,每行一个数字n
(n≤17


输出描述
对于每一行输入,输出1!+2!+3!+...+n!
的结果
(注意结果可能超出int的范围)
  1. #include<stdio.h>
  2. int main()
  3. {
  4.     long long n,i,a,sum=0,t=1;
  5.     while(scanf("%lld",&n)!=EOF)
  6.     {
  7.     for(i=1;i<=n;i++)
  8.     {
  9.             for(a=1;a<=i;a++)
  10.         {
  11.             t=a*t;
  12.         }
  13.             sum=sum+t;
  14.     }
  15.     printf("%lld\n",sum);
  16.         sum=0;t=1;
  17.     }
  18. }
复制代码
最佳答案
2023-10-11 16:26:01
这个程序的问题在于阶乘计算时没有将t清零,导致每次计算的结果都叠加在了一起。解决方法是在计算每个数的阶乘前将t清零。

修改后的代码如下:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     long long n, i, a, sum = 0, t = 1;
  5.     while (scanf("%lld", &n) != EOF)
  6.     {
  7.         for (i = 1; i <= n; i++)
  8.         {
  9.             t = 1; // 清零
  10.             for (a = 1; a <= i; a++)
  11.             {
  12.                 t = a * t;
  13.             }
  14.             sum = sum + t;
  15.         }
  16.         printf("%lld\n", sum);
  17.         sum = 0;
  18.     }
  19.     return 0;
  20. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-10-11 16:26:01 | 显示全部楼层    本楼为最佳答案   
这个程序的问题在于阶乘计算时没有将t清零,导致每次计算的结果都叠加在了一起。解决方法是在计算每个数的阶乘前将t清零。

修改后的代码如下:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     long long n, i, a, sum = 0, t = 1;
  5.     while (scanf("%lld", &n) != EOF)
  6.     {
  7.         for (i = 1; i <= n; i++)
  8.         {
  9.             t = 1; // 清零
  10.             for (a = 1; a <= i; a++)
  11.             {
  12.                 t = a * t;
  13.             }
  14.             sum = sum + t;
  15.         }
  16.         printf("%lld\n", sum);
  17.         sum = 0;
  18.     }
  19.     return 0;
  20. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-11 16:26:16 | 显示全部楼层
你的代码中存在一个问题,就是在计算阶乘的时候,你没有在每次计算完一个数的阶乘后将t重新设为1。这导致了你在计算阶乘的时候,实际上是在计算前一个数的阶乘的基础上继续乘以当前的数,而不是计算当前数的阶乘。

你的代码应该修改为如下形式:

  1. #include<stdio.h>

  2. int main() {
  3.     long long n,i,a,sum=0,t=1;
  4.     while(scanf("%lld",&n)!=EOF) {
  5.         for(i=1;i<=n;i++) {
  6.             t=1; // 将t重新设为1
  7.             for(a=1;a<=i;a++) {
  8.                 t=a*t;
  9.             }
  10.             sum=sum+t;
  11.         }
  12.         printf("%lld\
  13. ",sum);
  14.         sum=0;
  15.     }
  16. }
复制代码


在这个修改后的代码中,每次在计算一个新的数的阶乘之前,都会将t重新设为1,这样就能正确地计算每一个数的阶乘,然后将它们加起来。
请注意,本回答来自GPT-4
如果问题已经解决,请设置最佳答案
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-10-11 16:27:28 | 显示全部楼层
问题在于当n比较大时,阶乘的结果会超出long long的范围,从而导致计算错误。

可以考虑使用高精度来进行计算。将阶乘的结果存储在一个数组中,每位存储一个数字,每次乘法计算时对数组进行更新即可。

以下是修改后的代码:
  1. #include <stdio.h>
  2. #include <string.h>
  3. #define MAX_LEN 1000
  4. void multiply(int ans[], int n) {
  5.     int carry = 0;
  6.     for (int i = 0; i < MAX_LEN; i++) {
  7.         int tmp = ans[i] * n + carry;
  8.         ans[i] = tmp % 10;
  9.         carry = tmp / 10;
  10.     }
  11. }
  12. int main() {
  13.     int n;
  14.     while (scanf("%d", &n) != EOF) {
  15.         int ans[MAX_LEN] = {1}; // 存储阶乘的结果
  16.         int sum[MAX_LEN] = {0}; // 存储1!+2!+...+n!的结果
  17.         for (int i = 1; i <= n; i++) {
  18.             multiply(ans, i);
  19.             for (int j = 0; j < MAX_LEN; j++) {
  20.                 sum[j] += ans[j];
  21.             }
  22.         }
  23.         // 处理进位
  24.         for (int i = 0; i < MAX_LEN - 1; i++) {
  25.             sum[i + 1] += sum[i] / 10;
  26.             sum[i] %= 10;
  27.         }
  28.         // 找到最高位
  29.         int idx = MAX_LEN - 1;
  30.         while (idx > 0 && sum[idx] == 0) {
  31.             idx--;
  32.         }
  33.         // 输出结果
  34.         for (int i = idx; i >= 0; i--) {
  35.             printf("%d", sum[i]);
  36.         }
  37.         printf("\n");
  38.     }
  39.     return 0;
  40. }
复制代码

这里定义了一个multiply函数,用来计算阶乘。通过数组模拟阶乘的计算过程,然后将结果存储在数组中,最后将一次乘法的计算结果累加到sum数组中。

为了避免溢出,sum数组也使用了数组模拟,每位存储一个数字。最后输出时需要注意去掉前导零,并且反向输出结果。

这样就可以得到正确的答案了。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-9 13:57

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表