时间:2021-05-20
奶牛生子问题
描述:一只刚出生的奶牛,第4年开始生一只奶牛(假设只生母牛),以后每年生一只。现在给你一只刚出生的奶牛,求20年后有多少奶牛?
自己试着写了两个方法,不足之处,还望指正!
复制代码 代码如下:
// CowsChildren.cpp : 定义控制台应用程序的入口点。
#include "stdafx.h"
#include <iostream>
using namespace std;
//
int CalCowsNum1(int iYear)
{
int iCowNum = 1;
for (int iCnt = 1; iCnt <= iYear; iCnt++)
{
if (iCnt >= 4) //第四年奶牛数量开始增多
{
if ((iYear - iCnt) >= 4) //第2个四年,在第一个四年内出生的奶牛也开始生产
{
iCowNum += CalCowsNum1(iYear - iCnt);
}
else
{
iCowNum ++;
}
}
}
return iCowNum; //返回奶牛总数
}
//仿照斐波那契数列写的程序,当年的奶牛数量等于去年的奶牛数量加上新生的奶牛数量
//而当年新生的奶牛数量,又等于四年之前拥有的奶牛数量,因为四年之前的奶牛到当年
//都有了生成能力,并且一年生一个崽子(按照题意,生产的都是母牛,呵呵)
int CalCowsNum2(int iYear)
{
int iCowNum = 1;
if (iYear == 1 || iYear ==2 || iYear ==3) //前三年数量是1
{
return iCowNum;
}
if (iYear == 4)
{
iCowNum = 2; //第四年数量是2
return iCowNum;
}
return CalCowsNum2(iYear - 1) + CalCowsNum2(iYear - 4); //当年份大于4时,数量为前一年的数量加上四年前的数量
}//即f(n) = f(n-1) + f(n-4) (n>4时)
int _tmain(int argc, _TCHAR* argv[])
{
int iYear = 0;
cout << "Please input required years: " ;
cin >> iYear;
cout << endl << "The years you input is " << iYear
<< " and the number of cows is " << CalCowsNum1(iYear) << " "
<< CalCowsNum2(iYear)<< endl;
return 0;
}
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
探讨C++虚函数virtual有无虚函数的对比C++中的虚函数用于解决动态多态问题,虚函数的作用是允许在派生类中重新定义与积累同名的函数,并且可以通过基类指针或
在IT168看到这个对C++学习的探讨,感觉这个网友说的很实在,特转载放到这里与大家分享。1.为毛现在的C++教科书都那么枯燥无味?2.C++中的类这个概念很抽
这个问题主要考察的是C和C++的区别,以及C++中继承和多态的概念。C和C++的区别C语言是面向过程的语言,而C++是面向对象的过程。什么是面向对象和面向过程?
这个问题主要考察的是C和C++的区别,以及C++中继承和多态的概念。C和C++的区别C语言是面向过程的语言,而C++是面向对象的过程。什么是面向对象和面向过程?
本文较为深入的探讨了C++继承中的访问控制,对深入掌握C++面向对象程序设计是非常必要的。具体内容如下:通常来说,我们认为一个类有两种不同的用户:普通用户和类的