QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#423179#5956. Paradox SortKalenist32 ✓175ms3960kbC++201.2kb2024-05-27 21:26:012024-05-27 21:26:01

Judging History

你现在查看的是最新测评结果

  • [2024-05-27 21:26:01]
  • 评测
  • 测评结果:32
  • 用时:175ms
  • 内存:3960kb
  • [2024-05-27 21:26:01]
  • 提交

answer

#include<bits/stdc++.h>
#define N 110
#define For(i,a,b) for(register int i=a;i<=b;i++)
using namespace std;
int n,e[N][N],a[N],en;
bool ban[N],vis[N],mark[N];
char s[N][N];
inline void dfs(int x)
{
    mark[x]=true;
    For(i,1,n) if(!mark[i] && e[x][i]) dfs(i);
    return;
}

inline bool check(int x,int y)
{
    x=e[x][y]?x:y;
    For(i,0,n) mark[i]=ban[i];
    mark[y]=true;
    if(mark[en] && x != en) return false;
    if(!mark[en]) dfs(en);
    For(i,1,n) if(!mark[i] && !e[x][i]) return false;
    return true;
}

int main()
{
    int T;scanf("%d",&T);
    For(test,1,T)
    {
        scanf("%d%d",&n,&en),en++;
        memset(e,false,sizeof(e));
        For(i,1,n) scanf("%s",s[i]+1);
        For(i,1,n) For(j,i+1,n)
            if(s[i][j] == 'Y') e[i][j]=true;
            else e[j][i]=true;
        memset(ban,false,sizeof(ban));
        printf("Case #%d: ",test);
        if(!check(0,0)) {printf("IMPOSSIBLE\n");continue;}
        for(int lst=0,i=1;i<=n;i++)
            For(j,1,n) if(!ban[j] && check(lst,j))
            {
                ban[j]=true,printf("%d ",j-1);
                lst=e[lst][j]?lst:j;break;
            }
        printf("\n");
    }
    return 0;
}

詳細信息

Subtask #1:

score: 4
Accepted

Test #1:

score: 4
Accepted
time: 0ms
memory: 3960kb

input:

100
3 0
-YN
N-Y
YN-
2 0
-Y
N-
5 0
-YNNN
N-YNN
YN-YN
YYN-Y
YYYN-
5 1
-NYYY
Y-NNN
NY-NY
NYY-N
NYNY-
6 5
-YYNNY
N-YYNY
NN-NYN
YNY-NY
YYNY-Y
NNYNN-
4 0
-YYY
N-YN
NN-N
NYY-
2 0
-Y
N-
5 1
-NYNY
Y-YYY
NN-YY
YNN-N
NNNY-
7 5
-YYYYYY
N-NNYYN
NY-YNNN
NYN-NYN
NNYY-NN
NNYNY-N
NYYYYY-
8 0
-YNNNNNN
N-YNNNNN
YN-YNN...

output:

Case #1: 1 2 0 
Case #2: 0 1 
Case #3: 3 4 2 1 0 
Case #4: 0 2 3 4 1 
Case #5: 0 1 3 4 2 5 
Case #6: 0 1 2 3 
Case #7: 0 1 
Case #8: 0 1 2 3 4 
Case #9: IMPOSSIBLE
Case #10: 6 7 5 4 3 2 1 0 
Case #11: 0 1 2 
Case #12: 0 1 
Case #13: 0 1 
Case #14: IMPOSSIBLE
Case #15: IMPOSSIBLE
Case #16: 7 8 6 5 4 ...

result:

ok 100 lines

Subtask #2:

score: 28
Accepted

Test #2:

score: 28
Accepted
time: 175ms
memory: 3888kb

input:

100
39 0
-YNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN
N-YNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN
YN-YNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN
YYN-YNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN
YYYN-YNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN
YYYYN-YNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN
YYYYYN-YNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNN
YYYYYYN-YNN...

output:

Case #1: 37 38 36 35 34 33 32 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0 
Case #2: 0 13 23 28 30 34 38 40 41 42 43 46 49 51 52 33 5 1 17 32 15 29 19 10 16 47 48 9 4 27 6 7 18 31 8 11 26 50 3 37 25 35 45 20 24 39 22 12 44 36 2 21 14 
Case #3: 0 1 2 3 4 5 6 8...

result:

ok 100 lines

Extra Test:

score: 0
Extra Test Passed