解题思路:

首先需要实现循环输入,题目条件给出当输入0的时候程序结束,当输入其他数字时会返回那一年的母羊数量,所以我们可以采用一种循环嵌套条件语句的形式,当输入0的时候利用break跳出循环即可,当输入的不是0的时候可以使用一个递归函数,输出当时的函数值。

通过对前几年的数据进行分析,f(1)=1;f(2)=2;f(3)=3;f(4)=4;f(5)=6……可以看出f(4)=f(3)+f(1);f(5)=f(4)+f(2)……可以利用数学归纳法得出f(n)=f(n-1)+f(n-3),也可以利用题目条件进行分析,第n年所包含的母羊数量,既包括了第n-1年的母羊数量,也包含了在当年出生的小羊数量,由于刚刚出生的小母羊在四年之后才会生出其他小羊,所以在第n年出生的小羊数量均为在n-3年的母羊所生,因为在第n-3年的小羊正好到了四年的期限,且第n-1、n-2年出生的小羊仍不具有生殖能力。

综上所述,可以得出f(n)=f(n-1)+f(n-3)的递归关系式,只需要给出f(1)=1;f(2)=2;f(3)=3的初始条件,便可以利用函数的自身调用实现递归。


注意事项:

参考代码:

#include <stdio.h>

#include <math.h>


//递归函数的使用

int Num(int n)

{

    //给定初始化条件

    if (n == 1)

    {

        return 1;

    }

    else if (n == 2)

    {

        return 2;

    }

    else if (n == 3)

    {

        return 3;

    }

    else if (n == 4)

    {

        return 4;

    }

    //当n>3的时候,实现递归

    else

    {

        return Num(n - 1) + Num(n - 3);

    }

}


int main()

{

    int n = 0;


    while (1)

    {

        scanf("%d", &n);

        if (n == 0)

        {

            break;

        }

        else

        {

            printf("%d\n", Num(n));

        }

    }



    return 0;

}


点赞(0)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论