【蓝桥杯】[递归]母牛的故事

原题链接:https://www.dotcpp.com/oj/problem1004.html

目录

[1. 题目描述](#1. 题目描述)

[2. 思路分析](#2. 思路分析)

[3. 代码实现](#3. 代码实现)


1. 题目描述

2. 思路分析

我们列一个年份和母牛数量的表格:

通过观察,找规律,我们发现:

当年份小于等于4时,母牛数量和年份相等。

当年份大于4时,母牛数量等于这一年的前一年的母牛数量和这一年的第前三年的母牛数量之和。

f(n) = f(n - 1) + f(n - 3)

我们可以发现这个式子和**斐波那契数列f(n)=f(n-1)+f(n-2)**很像。

其次我们要注意这道题要多组输入,同时还要满足n==0时停止输入。我们就使用**while(cin>>n&&n)**满足这些要求。

3. 代码实现

cpp 复制代码
#include<iostream>
using namespace std;

int f(int n)
{
	if (n<=4) return n;
	return f(n - 1) + f(n - 3);
}
int main()
{
	int n;
	while (cin >> n && n)
	{
		cout << f(n) << endl;
	}
	return 0;
}
相关推荐
Vertira几秒前
matlab2022a 函数或变量 ‘knnclassify‘ 无法识别(已解决)
人工智能·算法·机器学习
倔强的石头1068 分钟前
【C++指南】C++中nullptr的深入解析
开发语言·c++
夏天天天天天天天#10 分钟前
深度优先搜索算法及其matlab程序详解
算法·matlab·深度优先·图论
笑鸿的学习笔记43 分钟前
qt-C++笔记之作用等同的宏和关键字
c++·笔记·qt
CrabKA1 小时前
C++Thread封装
c++·c++多线程
freexyn1 小时前
Matlab自学笔记36:日期时间型的概念、分类和创建方法
数据结构·笔记·算法·matlab
爱学习的真真子1 小时前
Lingo求解器基本语法
算法
大二转专业1 小时前
408算法题leetcode--第13天
考研·算法·leetcode
Kenneth風车2 小时前
【第十七章:Sentosa_DSML社区版-机器学习之异常检测】
人工智能·算法·低代码·机器学习·数据分析
武昌库里写JAVA5 小时前
人工智能不是人工“制”能
c语言·开发语言·数据结构·算法·二维数组