算法基础训练(三)微生物增殖

题目

假设有两种微生物 X 和 Y

X出生后每隔3分钟分裂一次(数目加倍),Y出生后每隔2分钟分裂一次(数目加倍)。

一个新出生的X半分钟之后吃掉1个Y,并且,从此开始,每隔1分钟吃1个Y

现在已知有新出生的 X=10, Y=89,求60分钟后Y的数目。

如果X=10,Y=90 呢?

分析

以半分钟为一个单位计算,60分钟也就是120个半分钟

代码

(一)C++

#include <iostream>
using namespace std;
int main()
{
    int X,Y;
    cin>>X>>Y;
    for(int i=1;i<=120;i++)
    {
        if(i%2==0)
        {
            Y-=X;   
            if(Y<0) Y=0;       
        } 
        if(i%4==0) Y*=2; //每隔两分钟 Y 就增加一倍   
        if(i%6==0) X*=2; // X出生后每隔 3 分钟分裂一次
    }
    cout<<X<<' '<<Y<<endl;
    system("pause"); 
}

(二)Java

import java.util.Scanner;

public class 微生物增殖 {
    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        System.out.print("X的初值为");
        int X = input.nextInt();
        System.out.print("Y的初值为");
        int Y = input.nextInt();
        for (int i = 1; i <= 120; i++) {
            if (i % 2 == 0) {
                Y -= X;
                if (Y < 0) {
                    Y = 0;
                }
            }

            if (i % 4 == 0) {
                Y *= 2;
            }//每隔两分钟 Y 就增加一倍

            if (i % 6 == 0) {
                X *= 2;
            }// X出生后每隔 3 分钟分裂一次
        }
        System.out.println("Y的数目为"+ Y);
    }
}

输出结果

Y的数目为94371840

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

isxhyeah

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值