关于#C语言#的问题,如何解决?

C语言ACM题目,与搜索有关
错误提示:Time Limit Exceeded.
希望指出如何修改代码可以通过测试

img

img

img

22行printf函数里,%d应该是%ld吧。
递归次数多的话,可以建一个3维数组,保存已经计算的函数的值
代码修改如下:

#include<stdio.h>
long arr[21][21][21] = { 0 };
long fun(long a, long b, long c)
{
    if (a <= 0 || b <= 0 || c <= 0)
        return 1;
    else if (a > 20 || b > 20 || c > 20)
    {
        if(arr[20][20][20] == 0)
            arr[20][20][20]= fun(20, 20, 20);
        return arr[20][20][20];
    }
    else if (a < b && b < c)
    {
        if (arr[a][b][c - 1] == 0)
            arr[a][b][c - 1] = fun(a, b, c - 1);
        if (arr[a][b - 1][c - 1] == 0)
            arr[a][b - 1][c - 1] = fun(a, b - 1, c - 1);
        if (arr[a][b - 1][c] == 0)
            arr[a][b - 1][c] = fun(a, b - 1, c);
        return arr[a][b][c - 1] + arr[a][b - 1][c - 1] - arr[a][b - 1][c];
    }
    else 
    {
        if (arr[a - 1][b][c] == 0)
            arr[a - 1][b][c] = fun(a - 1, b, c);
        if (arr[a - 1][b - 1][c] == 0)
            arr[a - 1][b - 1][c] = fun(a - 1, b - 1, c);
        if (arr[a - 1][b][c - 1] == 0)
            arr[a - 1][b][c - 1] = fun(a - 1, b, c - 1);
        if (arr[a - 1][b - 1][c - 1] == 0)
            arr[a - 1][b - 1][c - 1] = fun(a - 1, b - 1, c - 1);
        return arr[a - 1][b][c] + arr[a - 1][b - 1][c] + arr[a - 1][b][c - 1] - arr[a - 1][b - 1][c - 1];
    }
        
}

int main()
{
    long a = 0, b = 0, c = 0;
    while (scanf("%1d%ld%ld", &a, &b, &c) && !(a == -1 && b == -1 && c == -1))
    {
        long ret = fun(a, b, c);
        printf("w(%ld, %ld, %ld) = %ld\n", a, b, c, ret);
    }
    return 0;
}


您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632