$N$ players played a round-robin tournament. You are given an $N$-by-$N$ table $A$ containing the results of the matches. Let $A_{i,j}$ denote the element at the $i$-th row and $j$-th column of $A$. Determine whether the given table is contradictory. The table is said to be contradictory when some of the following holds:Problem Statement
$A_{i,j}$ is -
if $i=j$, and W
, L
, or D
otherwise.
$A_{i,j}$ is W
if Player $i$ beat Player $j$, L
if Player $i$ lost to Player $j$, and D
if Player $i$ drew with Player $j$.
Constraints
-
.W
, L
, or D
, for $i\neq j$.
Input
Input is given from Standard Input in the following format:
$N$ $A_{1,1}A_{1,2}\ldots A_{1,N}$ $A_{2,1}A_{2,2}\ldots A_{2,N}$ $\vdots$ $A_{N,1}A_{N,2}\ldots A_{N,N}$
Output
If the given table is not contradictory, print correct
; if it is contradictory, print incorrect
.
Sample Input 1
4 -WWW L-DD LD-W LDW-
Sample Output 1
incorrect
Player $3$ beat Player $4$, while Player $4$ also beat Player $3$, which is contradictory.
Sample Input 2
2 -D D-
Sample Output 2
correct
There is no contradiction.
如果 \(a_{i,j}=D,a_{j,i}=D\)
如果 \(a_{i,j}=L,a_{j,i}=W\)
判定即可。
#include<cstdio>
int n;
char s[1005][1005];
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%s",s[i]+1);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(i!=j)
{
if(s[i][j]=='W'&&s[j][i]!='L')
{
printf("incorrect");
return 0;
}
if(s[i][j]=='L'&&s[j][i]!='W')
{
printf("incorrect");
return 0;
}
if(s[i][j]=='D'&&s[j][i]!='D')
{
printf("incorrect");
return 0;
}
}
}
}
printf("correct");
}
标签:given,There,beat,Tournament,Player,contradictory,Result,table
From: https://www.cnblogs.com/mekoszc/p/16656127.html