鱼C论坛

 找回密码
 立即注册
查看: 579|回复: 1

[已解决]递归优化

[复制链接]
发表于 2020-12-30 16:17:26 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 一世轻尘 于 2020-12-30 17:32 编辑

xdm,这个要怎么写啊,我是这样写的,运行结果没有问题,但是题目好像要求必须要有个n,看不太懂这题目,求大佬帮我改一下。
#include<stdio.h>
#include<stdlib.h>
int num(int x);
int main()
{
    int n1[100]={0},a[100]={0},m,i;
    for(i=0;;i++)
    {
        scanf("%d",&n1[i]);
        if(n1[i]==0)
            break;
    }
    for(i=0;n1[i]!=0;i++)
    {
        a[i]=num(n1[i]);
    }
        i=0;
    while(a[i])
    {
        printf("%d\n",a[i]);
                i++;
    }
        system("pause");
    return 0;
}

int num(int x)
{
    if(x<5)
        return x;
    else
        return (x-3+num(x-1));
}
最佳答案
2020-12-31 01:28:22
输入输出你自己去改
#include <stdio.h>
int b, a[55] = { 0,1,2,3,4,0 };  // 初始化数组
int num(int n)
{
        if (n > 4)
        {
                a[n] = n - 3 + num(n - 1);
        }
        b = a[n];
        return b;
}

int main()
{
        int m, n;
        while (1)      // 若要循环输入,则要此循环,若输入一个年份,输出一个数据,则不需此循环
        {
                scanf("%d", &n);
                m = num(n);
                if (n != 0)
                        printf("%d\n", m);
        }
}
3.png
1.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-12-31 01:28:22 | 显示全部楼层    本楼为最佳答案   
输入输出你自己去改
#include <stdio.h>
int b, a[55] = { 0,1,2,3,4,0 };  // 初始化数组
int num(int n)
{
        if (n > 4)
        {
                a[n] = n - 3 + num(n - 1);
        }
        b = a[n];
        return b;
}

int main()
{
        int m, n;
        while (1)      // 若要循环输入,则要此循环,若输入一个年份,输出一个数据,则不需此循环
        {
                scanf("%d", &n);
                m = num(n);
                if (n != 0)
                        printf("%d\n", m);
        }
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-12 02:23

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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