蓝桥杯(B组)-每日一题

题目:

思路:

首先将所有牛分类

1.a第一头母牛-每年年初生一头小母牛

2.不能生小牛的牛:

b1-一岁小母牛

b2-二岁小母牛

b3-三岁小母牛

超过4岁就会再生一头小牛

因此计算每年生的小牛是第一头生的a再加上4岁后的生的

代码实现:

复制代码
#include<iostream>
using namespace std; 
int main()
{
    int a=1,b1=0,b2=0,b3=0,year[55];
//初始化如果第一头每年生一头的牛数量是1
//1岁的小牛
//2岁的小牛
//3岁的小牛都初始化为1

//第0年没有牛也初始化为0
    year[0]=0;
    year[1]=1;
//定义年数组来存放每一年有的牛数 

//进入循环从第2年到第55年
    for(int i=2;i<55;i++)
    {
        a=a+b3;
//每年的新生牛等于原先可以生的+去年3岁的
        year[i]=year[i-1]+a;
//去年的+新的
        b3=b2;//2岁的变成3岁 
        b2=b1;//1岁的变成2岁 
        b1=a;//新出生的   
     } 
     while(1)
//一直进行循环
{
    int p;//输入年数p
    cin>>p;
    if(p!=0)//如果不为0
    {
        cout<<year[p]<<endl;//将year数组中存储的年数打印
     } 
     else//如果为0的话直接结束
     break;
}
    return 0;
} 
相关推荐
GSDjisidi6 小时前
日本IT就职面试|仪容&礼仪篇分享建议
面试·职场和发展
skyang.11 小时前
LeetCode 85. 最大矩形
算法·leetcode·职场和发展
21 小时前
LeetCode Hot 100 括号生成
算法·leetcode·职场和发展
@蓝莓果粒茶2 天前
LeetCode第350题_两个数组的交集II
c++·python·学习·算法·leetcode·职场和发展·c#
YuTaoShao2 天前
【LeetCode 热题 100】51. N 皇后——回溯
java·算法·leetcode·职场和发展
测试19982 天前
cmake应用:集成gtest进行单元测试
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例
运维成长记2 天前
关于linux运维 出现高频的模块认知
运维·职场和发展·云计算
jackzhuoa2 天前
java小白闯关记第一天(两个数相加)
java·算法·蓝桥杯·期末
吃着火锅x唱着歌2 天前
LeetCode 611.有效三角形的个数
算法·leetcode·职场和发展
爱喝矿泉水的猛男2 天前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展