我希望你是我独家记忆

一段永远封存的记忆,随风而去
posts - 263, comments - 31, trackbacks - 0, articles - 3
   :: 首页 :: 新随笔 ::  :: 聚合  :: 管理

USACO 413--(floyed最小环)

Posted on 2008-07-30 12:23 Hero 阅读(295) 评论(0)  编辑 收藏 引用 所属分类: 代码如诗--ACM

/*
ID: wangzha4
LANG: C++
TASK: fence6
*/

//利用floyed算法求最小环--参见图片的算法

/*
Executing
   Test 1: TEST OK [0.000 secs, 2848 KB]
   Test 2: TEST OK [0.011 secs, 2852 KB]
   Test 3: TEST OK [0.000 secs, 2848 KB]
   Test 4: TEST OK [0.000 secs, 2848 KB]
   Test 5: TEST OK [0.011 secs, 2848 KB]
   Test 6: TEST OK [0.000 secs, 2848 KB]
   Test 7: TEST OK [0.000 secs, 2852 KB]
   Test 8: TEST OK [0.011 secs, 2852 KB]
   Test 9: TEST OK [0.000 secs, 2848 KB]
*/
#include 
<stdio.h>
#include 
<stdlib.h>
#include 
<string.h>
#include 
<ctype.h>
#define llong unsigned long long 
#define unint unsigned int
#define printline  printf( "\n" ) 

double fmax( double a, double b )
{
    
if( a - b > 0 )    return a ;
    
else            return b ;
}

double fmin( double a, double b )
{
    
if( a - b < 0 )    return a ;
    
else            return b ;
}

int fmax( int a, int b )
{
    
if( a > b )    return a ;
    
else        return b ;
}

int fmin( int a, int b )
{
    
if( a < b )    return a ;
    
else        return b ;
}

int fpow( int a, int b )
{
    
int reval = 1 ;
    
forint i=1; i<=b; i++ )
        reval 
*= a ;
    
return reval ;
}
const int INF = 1000000 ;
const int size = 120 ;

int inn ; int out = INF ;
int edge[size][size] ;
int dist[size][size] ;
int flen[size] ;
int left[size][10] ;
int right[size][10] ;
bool inleft[size][size] = { false } ;
int flag[size] = {0} ;

int minCircle()
{
//寻找最小环
    forint i=0; i<=inn; i++ ) forint j=0; j<=inn; j++ )
        dist[i][j] 
= edge[i][j] ;//dist数组初始化

    
int reval = INF ;
    
forint k=1; k<=inn; k++ )
    {
//枚举最大的点
        forint i=1; i<=left[k][0]; i++ ){//从最大点的左边选出小于当前最大点的左节点
            int curleft = left[k][i] ;
            
if( curleft < k ){
                
forint j=1; j<=right[k][0]; j++ ){//从最大点的右边选出小于当前最大点的右节点
                    int curright = right[k][j] ;
                    
if( curright < k ){
                        reval 
= fmin( reval, dist[curleft][curright]+edge[curleft][k]+edge[k][curright] ) ;
                    }
//构成环
                }
            }
        }

        
forint i=1; i<=inn; i++ ) forint j=1; j<=inn; j++ )
            
if( i==|| i==|| j==k )    continue ;
            
else    dist[i][j] = dist[j][i] = fmin( dist[i][j], dist[i][k]+dist[k][j] ) ;
    }

    
return reval ;
}

int main()
{
    freopen( 
"fence6.in""r", stdin ) ;
    freopen( 
"fence6.out","w",stdout ) ;

    scanf( 
"%d",&inn ) ; int fnum ;
    
forint i=1; i<=inn; i++ )
    {
        scanf( 
"%d",&fnum ) ;
        scanf( 
"%d",&flen[fnum] ) ;
        scanf( 
"%d %d",&left[fnum][0],&right[fnum][0] ) ;

        
forint j=1; j<=left[fnum][0]; j++ ){
            scanf( 
"%d",&left[fnum][j] ) ;
            inleft[fnum][left[fnum][j]] 
= true ;
        }
        
forint j=1; j<=right[fnum][0]; j++ ){
            scanf( 
"%d",&right[fnum][j] ) ;
        }
    }
//data input

    
forint i=0; i<=inn; i++ ){
        
forint j=0; j<=inn; j++ ){
            edge[i][j] 
= dist[i][j] = INF ;
        }
    }
//edge init

    
forint i=1; i<=inn; i++ )
    {
        
forint j=1; j<=left[i][0]; j++ )
            edge[i][left[i][j]] 
= flen[i] + flen[left[i][j]] ;
        
forint j=1; j<=right[i][0]; j++ )
            edge[i][right[i][j]] 
= flen[i] + flen[right[i][j]] ;
    }

    
out = minCircle() ;

    printf( 
"%d\n",out/2 ) ;

    
return 0 ;
}

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理