随笔 - 87  文章 - 279  trackbacks - 0
<2025年1月>
2930311234
567891011
12131415161718
19202122232425
2627282930311
2345678

潜心看书研究!

常用链接

留言簿(19)

随笔分类(81)

文章分类(89)

相册

ACM OJ

My friends

搜索

  •  

积分与排名

  • 积分 - 215489
  • 排名 - 116

最新评论

阅读排行榜

评论排行榜

const   int  MAXN  =   100 ;

class  UFset
{
public :
    
int  parent[MAXN];
    UFset();
    
int  Find( int );
    
void  Union( int int );
}
;

UFset::UFset()
{
    memset(parent, 
- 1 sizeof (parent));
}


int  UFset::Find( int  x)
{
    
if  (parent[x]  <   0 )
        
return  x;
    
else
        parent[x] 
=  Find(parent[x]);  //  压缩路径
}


void  UFset::Union( int  x,  int  y)
{
    
int  pX  =  Find(x);
    
int  pY  =  Find(y);
    
int  tmp;
    
if  (pX  !=  pY)
    
{
        tmp 
=  parent[pX]  +  parent[pY];  //  加权合并
         if  (parent[pX]  >  parent[pY])
        
{
            parent[pX] 
=  pY;
            parent[pY] 
=  tmp;
        }

        
else
        
{
            parent[pY] 
=  pX;
            parent[pX] 
=  tmp;
        }

    }

}


// int g[MAXN][MAXN];
struct  EDGEDATA
{
    
int  beg, end;
    
int  q;
}
;

EDGEDATA e[MAXN
* MAXN]; // 输入边信息
EDGEDATA v[MAXN]; // 返回路径

int  inorder(EDGEDATA a, EDGEDATA b)
{
    
return  a.q  <  b.q;
}


int  kruskal( int  nn,  int  n)  //  nn边数, n顶点数
{
    
int  i;
    
int  k;
    UFset UFS;
    
int  rnt  =   0 ;
    
//  e 已按权排序
     for  (i = 0 , k = 0 ; i < nn; i ++ )
    
{
        
if  (UFS.Find(e[i].beg)  !=  UFS.Find(e[i].end))
        
{
            v[k].beg 
=  e[i].beg;
            v[k].end 
=  e[i].end;
            v[k].q 
=  e[i].q;
            rnt 
+=  e[i].q;
            k
++ ;
            UFS.Union(e[i].beg, e[i].end);            
        }

        
if  (k  ==  n - 1 break ;
    }

    
return  rnt;
}
posted on 2006-08-20 01:39 阅读(718) 评论(0)  编辑 收藏 引用 所属分类: 数据结构与算法

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