本文主要是介绍22.蓝桥杯之微生物增殖,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
假设有两种微生物 X 和 Y
X出生后每隔3分钟分裂一次(数目加倍),Y出生后每隔2分钟分裂一次(数目加倍)。
一个新出生的X,半分钟之后吃掉1个Y,并且,从此开始,每隔1分钟吃1个Y。
现在已知有新出生的 X=10, Y=89,求60分钟后Y的数目。
如果X=10,Y=90 呢?
本题的要求就是写出这两种初始条件下,60分钟后Y的数目。
题目的结果令你震惊吗?这不是简单的数字游戏!真实的生物圈有着同样脆弱的性质!也许因为你消灭的那只 Y 就是最终导致 Y 种群灭绝的最后一根稻草!
importjava.util.Scanner;
publicclass Question22MustRemember {publicstaticvoid calculate(int primaryNumX,int primaryNumY,int timesOfMinute) {int numX=primaryNumX,numY=primaryNumY;for (int i = 2; i <=timesOfMinute*2; i++) {if(numY<=0){numY=0;break;}if(i%2==0){numY-=primaryNumX;// 当为整数分钟时,最初数目的生物X将进食同等数目的生物Y}elseif(i%2==1){numY-=(numX-primaryNumX); //当为半数分钟的奇数倍时,由最初的生物X增值产生的生物X将进食同等数目的生物Y}if(i%6==0){numX*=2; //三分钟的整数倍,生物X增值一倍}if(i%4==0){numY*=2; //两分钟的整数倍,生物Y增值一倍}}System.out.println(numY);}publicstaticvoid main(String[] args) {calculate(10, 89, 60);calculate(10, 90, 60);
// Scanner scanner=new Scanner(System.in);
// int numX=scanner.nextInt(),numY=scanner.nextInt();
// System.out.println(numX+" "+numY);}
}
支付宝扫红包,让我能够买杯咖啡,继续创作,谢谢大家!
这篇关于22.蓝桥杯之微生物增殖的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!