http://poj.org/problem?id=3084
/* @author: */
import java.util.*;
class ff
{
static int min( int a, int b ) {
return a< b?a:b;
}
class edge
{
int to;
int c, f;
int rev_i;
edge( int pa, int pb, int pc ) {
to = pa; c = pb; f = 0;
rev_i = pc;
}
}
edge e[][] = new edge[30][1000];
int en[] = new int[30];
boolean sign[] = new boolean[30];
void insert_edge( int from, int to, int limit )
{
e[from][en[from]] = new edge( to, limit, en[to] );
e[to][en[to]] = new edge( from, 0, en[from] );
en[from]++;
en[to]++;
}
void add_flow( edge ee, int d )
{
ee.f += d;
e[ ee.to ][ ee.rev_i ].f -= d;
}
int search( int k, int t, int best )
{
int i, m = en[k];
int temp;
edge ep;
sign[k] = true;
if( k == t )
return best;
for( i=0; i< m; i++ )
{
ep = e[k][i];
if( ep.f < ep.c && !sign[ ep.to ] )
{
if( ( temp = search( ep.to, t, min( best, ep.c - ep.f ) ) ) > 0 )
{
ep.f += temp;
e[ ep.to ][ ep.rev_i ].f -= temp;
return temp;
}
}
}
return 0;
}
int maxflow( int n, int s, int t )
{
int total = 0, add = 0;
do
{
total += add;
for( int i=0; i< 30; i++ )
sign[i] = false;
}
while( ( add = search( s, t, (1<< 30) ) ) > 0 );
return total;
}
}
class Main {
public static void main(String args[]) throws Exception
{
Scanner cin = new Scanner( System.in );
int t, n, m, i, j, ans, b = 0;
int h, g;
String w;
t = cin.nextInt();
while( t-- != 0 ) {
ff f = new ff();
n = cin.nextInt();
m = cin.nextInt();
for( i=0; i< n; i++ ) {
w = cin.next();
if( w.equals( "I" ) ) {
b = i;
f.insert_edge( n, i, 1000000 );
}
h = cin.nextInt();
for( j=0; j< h; j++ ) {
g = cin.nextInt();
f.insert_edge( g, i, 1 );
f.insert_edge( i, g, 1000000 );
}
}
ans = f.maxflow( n+1, n, m );
if( ans >= 1000000 )
System.out.println( "PANIC ROOM BREACH" );
else
System.out.println( ans );
}
return;
}
}
Meta
-
Recent Posts
Recent Comments
Archives
- May 2024
- April 2023
- February 2023
- January 2023
- December 2022
- November 2022
- September 2022
- June 2022
- July 2021
- January 2021
- February 2020
- September 2019
- March 2018
- February 2018
- August 2016
- July 2016
- June 2016
- May 2016
- April 2016
- March 2016
- February 2016
- January 2016
- December 2015
- November 2015
- October 2015
- September 2015
- August 2015
- July 2015
- June 2015
- May 2015
- April 2015
- March 2015
- February 2015
- January 2015
- December 2014
- November 2014
- October 2014
- September 2014
- August 2014
- July 2014
- June 2014
- May 2014
- April 2014
- March 2014
- February 2014
- January 2014
- December 2013
- November 2013
- October 2013
- September 2013
- August 2013
- July 2013
- June 2013
- May 2013
- April 2013
- March 2013
- February 2013
- January 2013
- December 2012
- November 2012
- October 2012
- September 2012
- August 2012
- July 2012
- June 2012
- May 2012
- April 2012
- March 2012
- February 2012
- January 2012
- December 2011
- November 2011
- October 2011
- September 2011
- August 2011
- July 2011
- June 2011
- May 2011
- April 2011
- March 2011
- February 2011
- January 2011
- December 2010
- November 2010
- October 2010
- September 2010
- August 2010
- July 2010
- June 2010
- May 2010
- April 2010
- March 2010
- February 2010
- January 2010
- December 2009
- November 2009
- October 2009
- September 2009
- August 2009
- July 2009
- June 2009
- May 2009
- April 2009
- March 2009
- February 2009
Categories
