递推递归练习--A(母牛的故事)

本文通过一道关于母牛繁殖的问题,介绍了如何使用递推关系解决实际问题。文章给出了清晰的解题步骤,并提供了完整的C++代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目简述:有一对夫妇买了一头母牛,母牛从第二年开始每年生一头小牛,每一头小牛从第四个年头开始每年年初也生一头小牛,求第n年有多少头牛。

解题思路:

1、第一年有一头牛a[i]=i+1=1(i=0);

2、第二年有两头牛a[i]=i+1=2;

3、第三年有三头牛a[i]=i+1=3;

4、第四年里第一年生的小牛也可以生牛,a[i]=a[i-1]+a[i-3];

由此找到递推关系。

源代码:

#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n;
    while (cin>>n)
    {
        if (n==0)
        break;
        int i;
        vector<int>v;
        for (i=0;i<n;i++)
        {
            if (i<4)
            v.push_back(i+1);
            else
            v.push_back(v[i-1]+v[i-3]);
        }
        cout<<v[i-1]<<endl;
        v.clear();
    }
    return 0;
}
解题感想:对于这样一个比较简单的递推题目,放在第一个题是来练手的。因为是中文所以做起来比较容易,而且关系比较容易找。比较简单的一道题目。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值