Innocence909 2021-11-23 17:46 采纳率: 100%
浏览 37
已结题

c语言–函数的递归调用

已知某数列为:
F(0)=F(1)=1; F(2)=0;
F(n)=F(n-1)-3F(n-2)+2F(n-3) (n>2)
要求:使用递归法编写这个函数,然后输出F(0)~F(10),求其中的最大值和最小值、值为0的项的个数以及调用这个函数的总次数。

  • 写回答

2条回答 默认 最新

  • CSDN专家-link 2021-11-23 18:03
    关注
    /*
    已知某数列为:
    F(0)=F(1)=1; F(2)=0;
    F(n)=F(n-1)-3F(n-2)+2F(n-3) (n>2)
    要求:使用递归法编写这个函数,然后输出F(0)~F(10),求其中的最大值和最小值、值为0的项的个数以及调用这个函数的总次数。
    */
    #include <stdio.h>
    
    int count = 0;
    int F(int n)
    {
        count++;
        if(n==0 || n==1)
            return 1;
        if(n==2)
            return 0;
        return F(n-1)-3*F(n-2)+2*F(n-3);
    }
    
    int main()
    {
        int i=0,max,min,d,num=0;
        for(i=0;i<=10;i++)
        {
            d = F(i);
            if(i==0)
                max = min = d;
            else 
            {
                if (max < d)
                    max = d;
                if(min > d)
                    min = d;
            }
            if(d == 0)
                num++;
            printf("F(%d)=%d\n",i,d);
        }
        printf("max=%d,min=%d\n",max,min):
        printf("0的数量为%d\n",num);
        printf("共调用函数%d次\n",count);
        return 0;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月12日
  • 已采纳回答 12月4日
  • 创建了问题 11月23日

悬赏问题

  • ¥30 Matlab打开默认名称带有/的光谱数据
  • ¥50 easyExcel模板 动态单元格合并列
  • ¥15 res.rows如何取值使用
  • ¥15 在odoo17开发环境中,怎么实现库存管理系统,或独立模块设计与AGV小车对接?开发方面应如何设计和开发?请详细解释MES或WMS在与AGV小车对接时需完成的设计和开发
  • ¥15 CSP算法实现EEG特征提取,哪一步错了?
  • ¥15 游戏盾如何溯源服务器真实ip?需要30个字。后面的字是凑数的
  • ¥15 vue3前端取消收藏的不会引用collectId
  • ¥15 delphi7 HMAC_SHA256方式加密
  • ¥15 关于#qt#的问题:我想实现qcustomplot完成坐标轴
  • ¥15 下列c语言代码为何输出了多余的空格