河南第五届ACM省赛(Metric Matrice)

题目地址:http://acm.nyist.net/JudgeOnline/problem.php?pid=545

思路:刚开始图省事在写一块了,没想到是尽量输出最小的不满足的序号

AC代码:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <stack>
#include <map>
#include <cstring>
#include <climits>
#include <cmath>
#include <cctype>

const int inf = 0x7f7f7f7f;//2139062143
typedef long long ll;
using namespace std;

int a[35][35];

int main()
{
    int t,n;
    int i,j,k;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d",&n);
        for(i=0; i<n; i++)
        {
            for(j=0; j<n; j++)
            {
                scanf("%d",&a[i][j]);
            }
        }
        for(i=0; i<n; i++)
        {
            if(a[i][i] != 0)
            {
                break;
            }
        }
        if(i != n)
        {
            printf("1\n");
            continue;
        }
        bool flag = false;
        for(i=0; i<n; i++)
        {
            for(j=0; j<n; j++)
            {
                if(i != j && a[i][j] <= 0)
                {
                    flag = true;
                    break;
                }
            }
            if(flag)
                break;
        }
        if(flag)
        {
            printf("2\n");
            continue;
        }
        flag =false;
        for(i=0; i<n; i++)
        {
            for(j=0; j<n; j++)
            {
                if(a[i][j] != a[j][i])
                {
                    flag = true;
                    break;
                }
            }
            if(flag)
                break;
        }
        if(flag)
        {
            printf("3\n");
            continue;
        }
        flag = false;
        for(i=0; i<n; i++)
        {
            for(j=0; j<n; j++)
            {
                if(i != j)
                {
                    for(k=0; k<n; k++)
                    {
                        if(j != k && i != k && a[i][j] + a[j][k] < a[i][k])
                        {
                            flag = true;
                            break;
                        }
                    }
                }
                if(flag)
                    break;
            }
            if(flag)
                break;
        }
        if(flag)
        {
            printf("4\n");
            continue;
        }
        printf("0\n");
    }
    return 0;
}
错误代码:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <algorithm>
#include <queue>
#include <stack>
#include <map>
#include <cstring>
#include <climits>
#include <cmath>
#include <cctype>

const int inf = 0x7f7f7f7f;//2139062143
typedef long long ll;
using namespace std;

int a[35][35];

int main()
{
    int t,n;
    int i,j,k;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d",&n);
        for(i=0; i<n; i++)
        {
            for(j=0; j<n; j++)
            {
                scanf("%d",&a[i][j]);
            }
        }
        for(i=0; i<n; i++)
        {
            for(j=0; j<n; j++)
            {
                if(i == j && a[i][j] != 0)
                {
                    printf("1\n");
                    goto loop;
                }
                if(i != j && a[i][j] <= 0)
                {
                    printf("2\n");
                    goto loop;
                }
                if(a[i][j] != a[j][i])
                {
                    printf("3\n");
                    goto loop;
                }
                for(k=0; k<n; k++)
                {
                    if(i != j && j != k && i != k && a[i][j] + a[j][k] < a[i][k])
                    {
                        printf("4\n");
                        goto loop;
                    }
                }
            }
        }
        printf("0\n");
        loop:;
    }
    return 0;
}

这样输出就不是最小的

你可能感兴趣的:(河南第五届ACM省赛(Metric Matrice))