Navy maneuvers
Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 400 Accepted Submission(s): 160
Problem Description
In times of peace, various countries have held regular maneuvers to maintain military’s vigilance. There is a navy fleet in a certain country which also starts a new round imaginary naval battle.
At the maneuver stage, the admiral intends to assess the combat effectiveness of two warships, “Victory” and “Glory”, so he lets two warships carry out countering exercises. Both of the warship commanders are young and promising, who graduated from naval academy as outstanding students. Not only have they had rich navigation direction experiences, but also have profound scientific knowledge, especially in mathematics.
The admiral appoints one marine area dotted with many islets. Suppose all these islets are occupied by the enemy, and there are positive integers of enemy firebases. The hypothetical exercise situations given by the admiral and the rule of the competition are as follows:
(1) All the occupied islets are connected. There are some routes among these islets, but the route from one islet to another islet is unidirectional. In other words, if we take an islet as a node and an islet route as an edge, then we will get a directed non-cyclic connected graph.
(2) There is a unique 1st islet in the graph. If we start from this islet, we can reach any other islet. (maybe the 1st islet is not the islet which is numbered 1)
(3) At the beginning of the maneuver, two warships simultaneously sail to the 1st islets and eliminate all enemy firebases together.
(4) The two warships, “Victory” and “Glory” take turns to navigate and exchange as soon as they arrive at an islet, then they move forward together. But each time they can only go along the unidirectional route, sail to the islet directly connected to the current, and eliminates all the enemy firebases on the islet. By the way, when start from 1st islet, “Victory” first navigates.
(5) Because each route is unidirectional, and graph is non-cycle, therefore the maneuver terminates when the two warships fail to go on navigating.
(6)When the maneuver ends, sum the numbers of eliminated enemy firebases on the routing path. If the number is greater than or equal to certain number f assigned by the admiral, then “Victory” wins. Otherwise, “Glory” wins.
The warship commanders are both mathematicians. After being assigned to such task, they see it is a Graph Theory problem. On the first simple directed non-cyclic connected graph, each node has a certain positive integer,it indicates the enemy firebases. The assignment is that two captains take turn to move forward along the directed edge until they are unable to do so. Then sum the total positive integers of the nodes on the routing path. Compare the number with the certain number f, and decides the final winning or losses.
Therefore, when it is the time for their own navigation, they are supposed to choose the route to win the final success.
Input
There are several test cases, in each case there are three positive integers n, m and f in first line. n indicates there are n (1< n <10000 ) nodes in the graph. The node serial number is arranged from 1 to n. m indicates that there are m edges in the graph. The following line has n positive integers, which indicate in sequence the positive integers in the nodes. Finally, there are m lines, and each line has two positive integers a, b (1< = a, b< =n), indicating there is a directed edge from the a node to the b node. Input is terminated by the end of file.
Output
To each group of the test case, if “Victory” wins, then output “Victory”. Otherwise, output “Glory”. The output each case takes up one line.
Sample Input
4 4 7
2 2 2 2
4 2
2 1
4 3
3 1
4 5 6
1 2 3 4
1 2
1 3
1 4
2 3
4 3
Sample Output
Source
2008 Asia Regional Harbin
Recommend
gaojie
#include<cstdio>
#include<cstring>
const int V=10010;
struct EDGE
{
int v,next;
} edge[V*100];
int head[V];
int node[V];
int in[V];
int tree[V][2];
int n,m,f;
int e;
int sum=0;
void addedge(int a,int b)
{
edge[e].v=b;
edge[e].next=head[a];
head[a]=e++;
}
int dfs(int u,int num)
{
if(num==1)
{
if(tree[u][1]!=0) return tree[u][1];
int big=-1;
for(int i=head[u];i!=-1;i=edge[i].next)
{
int v=edge[i].v;
int t=dfs(v,0);
if(t>big) big=t;
}
if(big!=-1) tree[u][1]=big+node[u];//如果big==-1说明到了叶子节点
else tree[u][1]=node[u];
return tree[u][1];
}
else
{
if(tree[u][0]!=0) return tree[u][0];
int min=100000000;
for(int i=head[u];i!=-1;i=edge[i].next)
{
int v=edge[i].v;
int t=dfs(v,1);
if(t<min) min=t;
}
if(min!=100000000) tree[u][0]=min+node[u];
else tree[u][0]=node[u];
return tree[u][0];
}
}
int main()
{
while(scanf("%d%d%d",&n,&m,&f)!=EOF)
{
e=0;
memset(in,0,sizeof(in));
memset(tree,0,sizeof(tree));
memset(head,-1,sizeof(head));
for(int i=1; i<=n; i++) scanf("%d",&node[i]);
for(int i=1; i<=m; i++)
{
int a,b;
scanf("%d%d",&a,&b);
addedge(a,b);
in[b]++;
//out[a]++;
}
for(int i=1; i<=n; i++)
if(in[i]==0)
{
sum=dfs(i,1);
break;
}
if(sum>=f) printf("Victory/n");
else printf("Glory/n");
}
return 0;
}