Civil and Evil Engineer(普林姆)

http://acm.sdut.edu.cn:8080/vjudge/contest/view.action?cid=198#problem/E

水题一道,题意就是让求一遍最小生成树与最大生成树,但我因为Each case contains a blank line and an integer n (1 ≤ n ≤ 100) denoting the number of houses.这句话错了三遍,有两种解决方案,一不用管空格,二gets(str);

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <math.h>
#define N 1000001
int map[101][101],map1[101][101];
int v[101],v1[101];
int dis[101],dis1[101];
int n;
int Primmin()
{
    int min,k,sum=0;
    memset(v,0,sizeof(v));
    v[0]=1;
    for(int i=0;i<=n;i++)
      dis[i]=map[0][i];
    for(int i=0;i<n;i++)
    {
        min=N;
        for(int j=0;j<=n;j++)
        {
            if(v[j]==0&&min>dis[j])
            {
                min=dis[j];
                k=j;
            }
        }
        v[k]=1;
        sum=sum+min;
        for(int j=0;j<=n;j++)
        {
            if(v[j]==0&&dis[j]>map[k][j])
            {
                dis[j]=map[k][j];
            }
        }
    }
    return sum;
}
int Primmax()
{
    int min,k,sum=0;
    memset(v1,0,sizeof(v1));
    v1[0]=1;
    for(int i=0;i<=n;i++)
      dis1[i]=map1[0][i];
    for(int i=0;i<n;i++)
    {
        min=0;
        for(int j=0;j<=n;j++)
        {
            if(v1[j]==0&&min<dis1[j])
            {
                min=dis1[j];
                k=j;
            }
        }
        sum=sum+min;
        v1[k]=1;
        for(int j=0;j<=n;j++)
        {
            if(v1[j]==0&&dis1[j]<map1[k][j])
            {
                dis1[j]=map1[k][j];
            }
        }
    }
    return sum;
}
int main()
{
    int T,K=0;
    char ch[101];
    scanf("%d",&T);
    while(T--)
    {
        K++;
        gets(ch);
        scanf("%d",&n);
        for(int i=0;i<=n;i++)
        {
            for(int j=0;j<=n;j++)
            {
                map[i][j]=N;
                map[j][i]=N;
            }
            map[i][i]=0;
        }
        for(int i=0;i<=n;i++)
        {
            for(int j=0;j<=n;j++)
            {
                map1[i][j]=0;
                map1[j][i]=0;
            }
        }
        int xx,yy,zz;
        while(scanf("%d%d%d",&xx,&yy,&zz)!=EOF)
        {
            if(xx==0&&yy==0&&zz==0)  break;
            if(map[xx][yy]>zz)
            {
                map[xx][yy]=zz;
                map[yy][xx]=zz;
            }
            if(map1[xx][yy]<zz)
            {
                map1[xx][yy]=zz;
                map1[yy][xx]=zz;
            }
        }
        int sum1=Primmin();
        int sum2=Primmax();
         long long int tt=sum1+sum2;
        if(tt%2==0)
        {
             tt=tt/2;
             printf("Case %d: %lld\n",K,tt);
        }
        else printf("Case %d: %lld/2\n",K,tt);
    }
    return 0;
}

 

posted @ 2014-08-02 15:49  人艰不拆_zmc  阅读(304)  评论(0编辑  收藏  举报