c++ 探讨奶牛生子的问题

 更新时间:2013年05月29日 11:16:47   作者:  
一只刚出生的奶牛,第4年开始生一只奶牛(假设只生母牛),以后每年生一只。现在给你一只刚出生的奶牛,求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;
}

相关文章

  • C++ 基础教程之虚函数实例代码详解

    C++ 基础教程之虚函数实例代码详解

    虚函数在 c++ 的继承体系中是一个非常重要概念,让我们可以在子类中复写父类的方法。这篇文章主要介绍了C++ 基础教程之虚函数实例代码的相关资料,需要的朋友可以参考下
    2020-02-02
  • C基础 redis缓存访问详解

    C基础 redis缓存访问详解

    下面小编就为大家带来一篇C基础 redis缓存访问详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • C语言 数与串之间转换的方法

    C语言 数与串之间转换的方法

    C语言 数与串之间转换的方法,需要的朋友可以参考一下
    2013-05-05
  • C语言实现图的最短路径Floyd算法

    C语言实现图的最短路径Floyd算法

    这篇文章主要为大家详细介绍了C语言实现图的最短路径Floyd算法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • OpenCV和C++实现图像的翻转(镜像)、平移、旋转、仿射与透视变换

    OpenCV和C++实现图像的翻转(镜像)、平移、旋转、仿射与透视变换

    这篇文章主要给大家介绍了关于OpenCV和C++实现图像的翻转(镜像)、平移、旋转、仿射与透视变换的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-09-09
  • C++ struct 初始化与赋值的实现

    C++ struct 初始化与赋值的实现

    在C++中初始化和赋值语句是两种不同的语法结构,本文主要介绍了C++ struct 初始化与赋值的实现,具有一定的参考价值,感兴趣的可以了解一下
    2025-03-03
  • C语言初学者代码中的常见错误与问题

    C语言初学者代码中的常见错误与问题

    C语言初学者犯过的很多错误都非常典型,在初学者中非常普遍,于是整理了一下,应该对其他初学者有借鉴意义
    2013-11-11
  • C++ std::condition_variable 条件变量用法解析

    C++ std::condition_variable 条件变量用法解析

    condition_variable(条件变量)是 C++11 中提供的一种多线程同步机制,它允许一个或多个线程等待另一个线程发出通知,以便能够有效地进行线程同步,这篇文章主要介绍了C++ std::condition_variable 条件变量用法,需要的朋友可以参考下
    2023-09-09
  • C++IO流之fstream, stringstream使用小结

    C++IO流之fstream, stringstream使用小结

    C语言中常用的输入输出函数有如下几种:前者是格式化标准输入输出,后者是格式化文件输入输出,最后是格式化字符串输入输出,这篇文章主要介绍了C++IO流:fstream, stringstream总结,需要的朋友可以参考下
    2022-04-04
  • C语言中你容易忽略的知识点与技巧总结

    C语言中你容易忽略的知识点与技巧总结

    这篇文章主要给大家介绍了关于C语言中你容易忽略的知识点与技巧,文中通过实例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-03-03

最新评论