QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#422323 | #5956. Paradox Sort | liqingyang | 32 ✓ | 173ms | 3684kb | C++17 | 1.1kb | 2024-05-27 11:43:21 | 2024-05-27 11:43:21 |
Judging History
answer
#include<iostream>
#include<cstring>
using namespace std;
int T,n,A;
char s[110][110];
bool a[110][110],Mark[110],mark[110];
void dfs(int now)
{
mark[now]=1;
for(int i=1;i<=n;i++)
{
if(mark[i]||!a[now][i])
{
continue;
}
dfs(i);
}
}
inline bool judge(int now,int x)
{
now=a[now][x]?now:x,Mark[x]=1;
memcpy(mark,Mark,sizeof(mark));
Mark[x]=0;
if(!mark[A])
{
dfs(A);
}
else if(now!=A)
{
return 0;
}
for(int i=1;i<=n;i++)
{
if(!mark[i]&&!a[now][i])
{
return 0;
}
}
return 1;
}
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cin>>T;
for(int I=1;I<=T;I++)
{
cin>>n>>A;
A++;
for(int i=1;i<=n;i++)
{
cin>>s[i]+1;
for(int j=1;j<=n;j++)
{
a[i][j]=(s[i][j]=='Y');
}
}
memset(Mark,0,sizeof(Mark));
cout<<"Case #"<<I<<": ";
if(!judge(0,0))
{
cout<<"IMPOSSIBLE"<<endl;
continue;
}
int now=0;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(!Mark[j]&&judge(now,j))
{
cout<<j-1<<" ";
Mark[j]=1,now=a[now][j]?now:j;
break;
}
}
}
cout<<endl;
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Subtask #1:
score: 4
Accepted
Test #1:
score: 4
Accepted
time: 1ms
memory: 3684kb
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: 173ms
memory: 3640kb
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