POJ 1258 Agri-Net

來源:互聯網
上載者:User

標籤:style   blog   io   2014   for   re   

題意:就是要你求最小產生樹所需的最小距離

思路:Kruskal演算法

AC代碼:

#include<stdio.h>#include<string.h>#include<algorithm>using namespace std;#define N 125000int u[N],v[N],w[N],r[N];int f[520],str[520][520];int find(int x){    if(x!=f[x])        f[x]=find(f[x]);    return f[x];}int cmp(const int x,const int y)    //間接排序距離{    return w[x]<w[y];}int main(){    int x,y,sum,e,i,j,n;    while(scanf("%d",&n)!=EOF)    {        int cnt=0;        memset(str,0,sizeof(str));        for(i=1;i<=n;i++)            for(j=1;j<=n;j++)            {                int val;                scanf("%d",&val);                if(val==0)                    continue;                if(!(str[i][j]&&str[j][i]))                {                    u[cnt]=i;                    v[cnt]=j;                    w[cnt++]=val;                    str[i][j]=str[j][i]=1;                }            }        for(i=0;i<=n;i++)f[i]=i;        for(i=0;i<=cnt;i++)r[i]=i;        sort(r,r+cnt,cmp);        sum=0;        for(i=0;i<=cnt;i++)        {            e=r[i];            x=find(u[e]);            y=find(v[e]);            if(x!=y){                sum+=w[e];                f[x]=y;            }        }        printf("%d\n",sum);    }}


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.