1312:【例3.4】昆虫繁殖
时间限制: 1000 ms 内存限制: 65536 KB
提交数: 34176 通过数: 17081【题目描述】
科学家在热带森林中发现了一种特殊的昆虫,这种昆虫的繁殖能力很强。每对成虫过xx个月产yy对卵,每对卵要过两个月长成成虫。假设每个成虫不死,第一个月只有一对成虫,且卵长成成虫后的第一个月不产卵(过xx个月产卵),问过zz个月以后,共有成虫多少对?0≤x≤20,1≤y≤20,X≤z≤500≤x≤20,1≤y≤20,X≤z≤50。
【输入】
x,y,zx,y,z的数值。
【输出】
过zz个月以后,共有成虫对数。
【输入样例】
1 2 8
【输出样例】
37
分析:
首先我们来看样例:每隔1个月产2对卵,求过8月(即第8+1=9月)的成虫个数
月份 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | … |
新增卵 | 0 | 2 | 2 | 2 | 6 | 10 | 14 | 26 | 46 | … |
成虫 | 1 | 1 | 1 | 3 | 5 | 7 | 13 | 23 | 37 | … |
设数组A[i]表示第i月新增的成虫个数。 由于新成虫每过x个月产y对卵,则可对每个A[i]作如下操作: A[i+k*x+2]:=A[i+k*x+2]+A[i]*y (1<=k,i+k*x+2<=z+1) 因为A [i]的求得只与A[1]~A[i-1]有关,即可用递推求法。 则总共的成虫个数为: