鱼C论坛

 找回密码
 立即注册
查看: 1282|回复: 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的范围)
#include<stdio.h>
int main()
{
    long long n,i,a,sum=0,t=1;
    while(scanf("%lld",&n)!=EOF)
    {
    for(i=1;i<=n;i++)
    {
            for(a=1;a<=i;a++)
        {
            t=a*t;
        }
            sum=sum+t;
    }
    printf("%lld\n",sum);
        sum=0;t=1;
    }
}
最佳答案
2023-10-11 16:26:01
这个程序的问题在于阶乘计算时没有将t清零,导致每次计算的结果都叠加在了一起。解决方法是在计算每个数的阶乘前将t清零。

修改后的代码如下:
#include <stdio.h>

int main()
{
    long long n, i, a, sum = 0, t = 1;
    while (scanf("%lld", &n) != EOF)
    {
        for (i = 1; i <= n; i++)
        {
            t = 1; // 清零
            for (a = 1; a <= i; a++)
            {
                t = a * t;
            }
            sum = sum + t;
        }
        printf("%lld\n", sum);
        sum = 0;
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

修改后的代码如下:
#include <stdio.h>

int main()
{
    long long n, i, a, sum = 0, t = 1;
    while (scanf("%lld", &n) != EOF)
    {
        for (i = 1; i <= n; i++)
        {
            t = 1; // 清零
            for (a = 1; a <= i; a++)
            {
                t = a * t;
            }
            sum = sum + t;
        }
        printf("%lld\n", sum);
        sum = 0;
    }
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

你的代码应该修改为如下形式:
#include<stdio.h>

int main() {
    long long n,i,a,sum=0,t=1;
    while(scanf("%lld",&n)!=EOF) {
        for(i=1;i<=n;i++) {
            t=1; // 将t重新设为1
            for(a=1;a<=i;a++) {
                t=a*t;
            }
            sum=sum+t;
        }
        printf("%lld\
",sum);
        sum=0;
    }
}

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

使用道具 举报

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

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

以下是修改后的代码:
#include <stdio.h>#include <string.h>#define MAX_LEN 1000void multiply(int ans[], int n) {    int carry = 0;    for (int i = 0; i < MAX_LEN; i++) {        int tmp = ans[i] * n + carry;        ans[i] = tmp % 10;        carry = tmp / 10;    }}int main() {    int n;    while (scanf("%d", &n) != EOF) {        int ans[MAX_LEN] = {1}; // 存储阶乘的结果        int sum[MAX_LEN] = {0}; // 存储1!+2!+...+n!的结果        for (int i = 1; i <= n; i++) {            multiply(ans, i);            for (int j = 0; j < MAX_LEN; j++) {                sum[j] += ans[j];            }        }        // 处理进位        for (int i = 0; i < MAX_LEN - 1; i++) {            sum[i + 1] += sum[i] / 10;            sum[i] %= 10;        }        // 找到最高位        int idx = MAX_LEN - 1;        while (idx > 0 && sum[idx] == 0) {            idx--;        }        // 输出结果        for (int i = idx; i >= 0; i--) {            printf("%d", sum[i]);        }        printf("\n");    }    return 0;}
这里定义了一个multiply函数,用来计算阶乘。通过数组模拟阶乘的计算过程,然后将结果存储在数组中,最后将一次乘法的计算结果累加到sum数组中。

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

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

球一个最佳答案谢谢啦!这对我非常重要!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-24 00:26

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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