24h購物| | PChome| 登入
2012-04-07 07:17:02| 人氣1,038| 回應0 | 上一篇 | 下一篇

[UVA][LIS] 497 - Strategic Defense Initiative

推薦 0 收藏 0 轉貼0 訂閱站台

Strategic Defense Initiative 

``Commander! Commander! Please wake up commander!''

``... mmmph. What time is it?''

``4:07 am, Commander. The following message just arrived on the emergency zeta priority classified scrambler, marked your eyes only.''

You grudgingly take the letter, rub the sleep from your eyes, fleetingly wish that the 'Backer closed at an earlier hour, and start to read.

``Dear StarWars SDI Commander,

    Bad news, buddy. Crazy Boris had a bit too much vodka last night
    and when he woke up this morning, instead of the snooze button
    on his alarm clock, he ... well, let me put it this way: we've got
    tons of nuclear missles flying this way. Unfortunately, all that
    we have is a chart of the altitudes at which the missles are
    flying, arranged by the order of arrivals. Go for it, buddy.
    Good luck.

                                           Secretary of Defense

    P.S. Hilly and Bill say hi.''

To make things worse, you remeber that SDI has a fatal flaw due to the budget cuts. When SDI sends out missles to intercept the targets, every missle has to fly higher than the previous one. In other words, once you hit a target, the next target can only be among the ones that are flying at higher altitudes than the one you just hit.

For example, if the missles are flying toward you at heights of 1, 6, 2, 3, and 5 (arriving in that order), you can try to intercept the first two, but then you won't be able to get the ones flying at 2, 3, 5 because they are lower than 6. Your job is to hit as many targets as possible. So you have to quickly write a program to find the best sequence of targets that the flawed SDI program is going to destroy.

Russian war tactics are fairly strange; their generals are stickers for mathematical precision. Their missles will always be fired in a sequence such that there will only be one solution to the problem posed above.

Input and Output

The input begins with a single positive integer on a line by itself indicating the number of the cases following, each of them as described below. This line is followed by a blank line, and there is also a blank line between two consecutive inputs.

each input to your program will consist of a sequence of integer altitudes, each on a separate line.

For each test case, the output must follow the description below. The outputs of two consecutive cases will be separated by a blank line.

Output from your program should contain the total number of targets you can hit, followed by the altitudes of those targets, one per line, in the order of their arrivals.

Sample Input

1

1
6
2
3
5

Sample Output

Max hits: 4
1
2
3
5


C++ 編譯

#include <stdio.h>
#include <string.h>

struct LIS {
int A[1000], n, maxLIS;
int pos[1000], lis[1000];
void findLIS() {
int i, l, m, r, newSet;
maxLIS = -1;
for(i = 0; i < n; i++) {
l = 0, r = maxLIS, newSet = -1;
while(l <= r) {
m = (l+r)/2;
if(pos[m] <= A[i]) {
if(m == maxLIS || pos[m+1] > A[i]) {
newSet = m+1;
break;
} else
l = m+1;
} else
r = m-1;
}
if(newSet == -1)
newSet = 0;
pos[newSet] = A[i];
lis[i] = newSet+1;
if(maxLIS < newSet)
maxLIS = newSet;
}
maxLIS++;
}
void printLIS() {
int ans[1000], at = 0, i, tmp = maxLIS;
for(i = n-1; i >= 0; i--) {
if(lis[i] == tmp)
tmp--, ans[at++] = A[i];
}
for(i = at-1; i >= 0; i--)
printf("%d\n", ans[i]);
}
};
int main() {
int t, n;
char str[100];
LIS data;
scanf("%d", &t);
getchar();
getchar();
while(t--) {
n = 0;
while(gets(str)) {
if(str[0] == '\0')
break;
sscanf(str, "%d", &data.A[n]);
n++;
}
data.n = n;
data.findLIS();
printf("Max hits: %d\n", data.maxLIS);
data.printLIS();
if(t)
puts("");
}
return 0;
}

台長: Morris
人氣(1,038) | 回應(0)| 推薦 (0)| 收藏 (0)| 轉寄
全站分類: 不分類 | 個人分類: UVA |
此分類下一篇:[UVA][DP] 10313 - Pay the Price
此分類上一篇:[UVA][DP] 435 - Block Voting

是 (若未登入"個人新聞台帳號"則看不到回覆唷!)
* 請輸入識別碼:
請輸入圖片中算式的結果(可能為0) 
(有*為必填)
TOP
詳全文