求N年后农场的奶牛数量

class Cow
{
    public int age = 1;// 初始化年龄为1岁
}
 
/// <summary>
/// 一个农场有头母牛,现在母牛才一岁,要到四岁才能生小牛,四岁之后,每年生一头小牛。
/// 假设每次生的都是母牛,并且也遵守4年才生育并生母牛的原则,并且无死亡,请问n年后共有多少头牛?
/// </summary>
static void Main(string[] args)
{
    List<Cow> cows = new List<Cow>();
    Cow cow = new Cow();
    cows.Add(cow);
    int n = 10;// 10年
    for (int i = 1; i <= n; i++)
    {
        //如果直接把cows.Count作为循环结束条件,那么在下面的泛型集合循环时会动态变化导致循环次数变多
        int temp = cows.Count;
 
        for (int j = 0; j < temp; j++)
        {
            cows[j].age++;// 循环一次过了1年,年龄++
            if (cows[j].age >= 4)//遍历集合中所有的牛,年龄大于等于4岁的则生一头小母牛
            {
                cow = new Cow();
                cows.Add(cow);
            }
        }
    }
    Console.WriteLine("{0}年后农场共有{1}头奶牛", n, cows.Count);
    Console.ReadLine();
}
在 3024 年,bessie 依然是 E 星球最大的农场主,一共有 n 个牛群,牛群 1∼n 编号,每个牛群都有一定数量奶牛。bessie 隔一段时间,会向第 l 到第 r 的牛群中的每个牛群增加 c 头奶牛。在增加 p 次后,bessie 进行 q 次查询,每次查询,需要知道奶牛数量最接近 x 并且不小于 x 头的牛群与原来的编号是多少(如果有相同数字,输出最靠左的编号)? 输入描述 输入包含两个整数 n,p。 输入一行 n 个数。 接下来 p 行,每行三个整数 l,r,c,表示第 l 到第 r 的区间内,每个牛群增加 c 头奶牛。 接下来输入一个 q。 接下来 q 行,每行一个 x。 输出描述 最后输出bessie 隔一段时间,会向第 l 到第 r 的牛群中的每个牛群增加 c 头奶牛。在增加 p 次后,bessie有 q 次查询,每次查询,需要知道奶牛数量最接近 x 并且不小于 x 头的牛群原来的编号是多少(如果有相同数字,输出最靠左的数据原来的编号,并且相同数据按照输入顺序排列)? 样例输入 1 8 3 1 2 10 8 1 5 1 1 7 8 12 1 8 4 2 3 12 2 18 17 样例输出 1 2 7数据范围与提示 5≤n,p≤100000,q≤1000000,1≤c≤10000,4<l,r,x<n,每个牛群的初始牛的数量不超过 1000000。 样例解释 1 2 10 8 1 5 1 1 第 7 到第 8 增加 12 1 2 10 8 1 5 13 13 第 1 到第 8 增加 4 5 6 14 12 5 9 17 17 第 2 到第 3 增加 12 5 18 26 12 5 9 17 17 2组查询 18 在原来的最初的编号中是 2。 17 在原来序列中 第 7 个在前面,所以原来的编号是 7(稳定排序)
03-16
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值