POJ2485

#include <iostream>
#include <stdio.h>
#include <string.h>


using namespace std;


int low[10000];
int vis[10000];
int map[600][600];






int prim(int n)
{
int i,j;
int t;
for(i=1;i<=n;i++)
{
low[i]=map[1][i];
vis[i]=0;
}


for(i=1;i<=n;i++)
{
int min= 0x3f3f3f;
for(j=1;j<=n;j++)
if(!vis[j] && low[j]<min){
min = low[j];
t=j;
     }


vis[t]=1;


for(j=1;j<=n;j++){
if(!vis[j] && map[t][j]<low[j])
low[j]=map[t][j];
}
}
int max=-1;
for(i=1;i<=n;i++)
if(low[i]>max) max=low[i];
return max;
}




int main()
{
    int n,f,c;
    int i,j;
    scanf("%d",&f);
    while(f--)
    {
        scanf("%d",&n);
        for(  i = 1; i<=n; i++)
         {
             for(  j = 1; j<=n; j++)
            {
              scanf("%d",&c);
                 map[i][j] = c;


            }
         }
         cout<<prim(n)<<endl;
    }
}

你可能感兴趣的:(POJ2485)