微生物增值
题目
假设有两种微生物 X 和 Y,X出生后每隔3分钟分裂一次(数目加倍),Y出生后每隔2分钟分裂一次(数目加倍)。
一个新出生的X,半分钟之后吃掉1个Y,并且,从此开始,每隔1分钟吃1个Y。
现在会给定一个n(n<=60并且n为整数)让你计算n分钟之后y的数量。
输入
第一行输入 n,x,y
10 2 20
输出
输出n分钟之后y的数量 若y<=0时输出y=0
240
思路
把半分钟看做一个单位,那 x 分裂:time % 6 == 0 ; y 分裂 :time % 4 == 0 ; x 吃 y : x%2 == 1
代码
#include<iostream>
using namespace std;
int main()
{
int n,a,b;
cin>>n>>a>>b;
for(int i=1;i<=n;i++)
{
if(i%2==1) b=b-a;
if(b<0)
{
b=0;
break;
}
if(i%6==0) a *= 2;
if(i%4==0) b *= 2;
}
cout<<b;
return 0;
}