//第三屆藍(lán)橋杯軟件類省賽真題-C-A-1_微生物增殖/* 假設(shè)有兩種微生物 X 和 Y X出生后每隔3分鐘分裂一次(數(shù)目加倍),Y出生后每隔2分鐘分裂一次(數(shù)目加倍)。 一個(gè)新出生的X,半分鐘之后吃掉1個(gè)Y,并且,從此開始,每隔1分鐘吃1個(gè)Y。 現(xiàn)在已知有新出生的 X=10, Y=89,求60分鐘后Y的數(shù)目。 如果X=10,Y=90 呢? 本題的要求就是寫出這兩種初始條件下,60分鐘后Y的數(shù)目。 題目的結(jié)果令你震驚嗎?這不是簡單的數(shù)字游戲!真實(shí)的生物圈有著同樣脆弱的性質(zhì)! 也許因?yàn)槟阆麥绲哪侵?Y 就是最終導(dǎo)致 Y 種群滅絕的最后一根稻草! 請忍住悲傷,把答案寫在“解答.txt”中,不要寫在這里!*//*【解題思路】解法: 根據(jù)題目來for循環(huán)邏輯運(yùn)算,且可以把分鐘轉(zhuǎn)化為秒來運(yùn)算, 避免浮點(diǎn)數(shù)運(yùn)算(如半分鐘) 其中列表找規(guī)律可得出: 可以不用管X是半分鐘吃一個(gè)Y,還是一分鐘吃一個(gè)Y, 都可以算成一分鐘吃一個(gè)Y, 比如一個(gè)新出生的X,它在0.5分鐘的時(shí)候吃了一個(gè)Y, 在第1.5分鐘吃一個(gè),2.5分鐘又吃了一個(gè), 也就是說,三分鐘內(nèi),X吃了3個(gè)Y,且題目要求的是60分鐘,能被3整除, 所以在運(yùn)算中可以直接轉(zhuǎn)變?yōu)閄每分鐘吃了1個(gè)Y 答案:94371840*/#include<iostream>using namespace std;int main(){ int x,y; x = 10; y = 90; for(int i=1;i<=3600;i++) { if(y < 0) { y=0; break; } if(i % 60 == 0) { y -= x; } if(i % 120 == 0) { y *= 2; } if(i % 180 == 0) { x *= 2; } } cout<<"當(dāng)X=10,Y=90時(shí),60分鐘后Y的數(shù)目為:"<<y<<endl; return 0;}
新聞熱點(diǎn)
疑難解答