HDU 最少攔截系統 (dp)
最少攔截系統
Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other)
Total Submission(s) : 10 Accepted Submission(s) : 4
Font: Times New Roman | Verdana | Georgia
Font Size: ← →
Problem Description
某國為了防御敵國的導彈襲擊,發展出一種導彈攔截系統.但是這種導彈攔截系統有一個缺陷:雖然它的第一發炮彈能夠到達任意的高度,但是以後每一發炮彈都不能超過前一發的高度.某天,雷達捕捉到敵國的導彈來襲.由於該系統還在試用階段,所以只有一套系統,因此有可能不能攔截所有的導彈.
怎麼辦呢?多搞幾套系統呗!你說說倒蠻容易,成本呢?成本是個大問題啊.所以俺就到這裡來求救了,請幫助計算一下最少需要多少套攔截系統.
Input
輸入若干組數據.每組數據包括:導彈總個數(正整數),導彈依此飛來的高度(雷達給出的高度數據是不大於30000的正整數,用空格分隔)
Output
對應每組數據輸出攔截所有導彈最少要配備多少套這種導彈攔截系統.
Sample Input
8 389 207 155 300 299 170 158 65
Sample Output
2
Source
浙江工業大學第四屆大學生程序設計競賽 AC代碼:
#include
#include
#include
#include
using namespace std;
int main(){
int n;
int dp[1111],i,j,a[1111];
while(cin>>n){
int out=0;
for(i=0;i>a[i];
dp[i]=1;
}
for(i=0;i=0;--j){
if(a[i]>a[j]&&dp[j]+1>dp[i])
dp[i]=dp[j]+1;
}
out=out>dp[i]?out:dp[i];
}
printf("%d\n",out);
}
return 0;
}