hdu-3632 A Captivating Match(区间dp)

link
A Captivating Match

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 437 Accepted Submission(s): 201

Problem Description
The FIFA 2010 Soccer World Cup has gone, Small Jan returned to her own planet. After she saw the Spain emerged the biggest winner, she believe that, as a Queen, she can also arrange a captivating match-International Cavalry PK Contest(ACM-ICPC) for her lovely and hard working subjects. But her subjects are so busying that they have no time to watch the group match. So, our smart Queen wants to make the final more valuable. Every Knight has a value in people’s minds and the final’s value is dependent on the last valiancy Knights (equals to the winner’s value).
Now assuming that the Knights have been numbered from 1 to N, and any time Small Jan could arrange a match between any two Knights adjacent to each other, but the loser will quit. For example, (1, 2, 3, 4, 5),if the Queen arranged Knights 3 and 4 for a match and Knight 3 lost, then Knights 2 and 4 would be adjacent to each other (the result of each Knight competing with others is saved in a table).
Here, Small Jan want to know the max value of the final, can you help her?

Input
The first line of the input is a single positive integer T(0 < T <= 30), telling the number of test scenarios to follow.
Each scenario begins with a line containing an integer N, 0 < N <= 100, being the number of Knights.
The following line contains N integers, 0 < Vi < 1000, being the value of each Knight in people’s minds.
Thelast is a N × N matrix. If a[i,j] = 1 indicate when Knight i competing with j, Knight i always win, which also means a[j, i] must equals 0 and if i=j, a[i,j] must equals 0.

Output
For each input case, output a line containing a single number, which is the max value of the final, following the case number (start with 1)

Sample Input

2
3
1 2 3
0 1 0
0 0 1
1 0 0
3
1 2 3
0 1 1
0 0 0
0 1 0

Sample Output

Case 1: 3
Case 2: 1

#include<string.h>
#include<stdio.h>
const int MAXN=111;
int beat[MAXN][MAXN];
bool map[MAXN][MAXN];
int a[MAXN];
int main(){
    int t;
    int n;
    int cas=1;
    scanf("%d",&t);
    for(int i=1;i<=t;i++){
        scanf("%d",&n);
        for(int i=1;i<=n;i++)scanf("%d",&a[i]);
        for(int i=1;i<=n;i++)
            for(int j=1;j<=n;j++)
                scanf("%d",&beat[i][j]);

        for(int i=1;i<=n;i++) beat[0][i]=beat[n+1][i]=0,
        beat[i][0]=beat[i][n+1]=1;
        memset(map,0,sizeof(map));
        for(int i=0;i<=n+1;i++)map[i][i+1]=map[i][i]=1;

        for(int k=2;k<=n;k++)
            for(int i=0,j=k;j<=n+1;i++,j++)
            {
                for(int l=i+1;l<=j-1;l++)
                if(map[i][l]&&map[l][j])
                {
                    if(beat[i][l])map[i][j]=1;
                    if(beat[j][l])map[i][j]=1;
                }
            }
            int ans=-1;
            for(int i=1;i<=n;i++)
            if(map[0][i]&&map[i][n+1]&&a[i]>ans)ans=a[i];
            printf("Case %d: %d\n",cas++,ans);
    }
    return 0;
}
posted @ 2017-04-25 19:41  考研小黑  阅读(3)  评论(0编辑  收藏  举报