QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#77590#5509. Kooky Tic-Tac-Toechenshi#AC ✓19ms1760kbC++2.0kb2023-02-15 09:48:052023-02-15 09:48:07

Judging History

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

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-02-15 09:48:07]
  • 评测
  • 测评结果:AC
  • 用时:19ms
  • 内存:1760kb
  • [2023-02-15 09:48:05]
  • 提交

answer

#include<cstdio>
using namespace std;
int z,n,K,c1,c2,fir;char s[9][9];
inline bool chk(){
	for(int i=1;i<=n;++i) for(int j=1,flg;j<=n-K+1;++j) if(s[i][j]^'.'){
		flg=1;
		for(int k=j+1;k<j+K&&flg;++k) flg=(s[i][k]==s[i][j]);
		if(flg) return false;
	}
	for(int i=1;i<=n-K+1;++i) for(int j=1,flg;j<=n;++j) if(s[i][j]^'.'){
		flg=1;
		for(int k=i+1;k<i+K&&flg;++k) flg=(s[k][j]==s[i][j]);
		if(flg) return false;
	}
	for(int i=1;i<=n-K+1;++i) for(int j=1,flg;j<=n-K+1;++j) if(s[i][j]^'.'){
		flg=1;
		for(int k=1;k<K&&flg;++k) flg=(s[i+k][j+k]==s[i][j]);
		if(flg) return false;
	}
	for(int i=1;i<=n-K+1;++i) for(int j=K,flg;j<=n;++j) if(s[i][j]^'.'){
		flg=1;
		for(int k=1;k<K&&flg;++k) flg=(s[i+k][j-k]==s[i][j]);
		if(flg) return false;
	}
	return true;
}
inline void print(int t){
	for(int i=1;i<=n;++i) for(int j=1;j<=n;++j){
		if(s[i][j]=='o'&&t%2==fir%2){printf("%d %d\n",i,j);s[i][j]='.';return;}
		if(s[i][j]=='x'&&t%2-fir%2){printf("%d %d\n",i,j);s[i][j]='.';return;}
	}
}
inline void slv(){
	scanf("%d%d",&n,&K);c1=c2=0;
	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) c1+=(s[i][j]=='o'),c2+=(s[i][j]=='x');
	if(c1>c2+1||c2>c1+1){printf("NIE\n");return;}
	if(chk()){
		if(c1+c2-n*n){printf("NIE\n");return;}
		if(c1>c2) fir=1;
		else fir=2;
		printf("TAK\n");
		for(int i=1;i<=c1+c2;++i) print(i);
		return;
	}
	for(int i=1;i<=n;++i) for(int j=1;j<=n;++j){
		if(s[i][j]=='o'&&c1>c2-1){
			s[i][j]='.';
			if(chk()){
				--c1;
				if(c1<c2) fir=2;
				else fir=1;
				printf("TAK\n");
				for(int k=1;k<=c1+c2;++k) print(k);
				printf("%d %d\n",i,j);
				return;
			}
			s[i][j]='o';
		}
		if(s[i][j]=='x'&&c2>c1-1){
			s[i][j]='.';
			if(chk()){
				--c2;
				if(c2<c1) fir=1;
				else fir=2;
				printf("TAK\n");
				for(int k=1;k<=c1+c2;++k) print(k);
				printf("%d %d\n",i,j);
				return;
			}
			s[i][j]='x';
		}
	}
	printf("NIE\n");
}
int main(){
	for(scanf("%d",&z);z--;slv());
	return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 1760kb

input:

7
3 3
x.o
xxx
o.o
4 3
xx.x
...o
..o.
.o..
3 3
xoo
oxx
xoo
3 2
xoo
oxx
xoo
3 3
xox
.o.
xox
3 2
xo.
..x
xo.
3 3
x..
.x.
..x

output:

TAK
1 1
1 3
2 2
3 1
2 3
3 3
2 1
TAK
1 1
3 3
1 2
4 2
1 4
2 4
TAK
1 2
1 1
1 3
2 2
2 1
2 3
3 2
3 1
3 3
NIE
NIE
NIE
NIE

result:

ok correct (7 test cases)

Test #2:

score: 0
Accepted
time: 9ms
memory: 1620kb

input:

10000
3 3
x.o
xxx
o.o
3 3
xoo
oxx
xoo
3 2
xoo
oxx
xoo
3 3
xox
.o.
xox
3 2
xo.
..x
xo.
3 2
oox
.xo
o.x
5 5
xxx..
xxo.x
xoo..
xxxox
.oooo
3 3
xxx
.o.
oo.
3 2
x.o
xo.
..o
3 2
..x
xxo
.o.
3 3
xxo
o..
oxo
3 2
oox
..x
...
3 3
xxo
...
.ox
3 3
.xo
...
oox
3 3
.x.
xo.
o.o
3 2
o..
xxo
.ox
3 2
x.x
xoo
x.o
3 2
...

output:

TAK
1 1
1 3
2 2
3 1
2 3
3 3
2 1
TAK
1 2
1 1
1 3
2 2
2 1
2 3
3 2
3 1
3 3
NIE
NIE
NIE
NIE
NIE
TAK
2 2
1 2
3 1
1 3
3 2
1 1
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
TAK
1 2
1 1
1 3
1 4
2 3
2 2
2 4
4 2
3 1
4 3
3 2
4 1
NIE
NIE
NIE
NIE
NIE
TAK
2 1
1 1
2 3
1 3
2 4
1 4
3 1
2 2
3 3
3 2
...

result:

ok correct (10000 test cases)

Test #3:

score: 0
Accepted
time: 19ms
memory: 1748kb

input:

10000
6 4
x.xx.o
xo.o.x
ooox.o
o..xo.
..xxxo
o.oxx.
6 5
oooxxx
oxoxxo
xoooxo
xoxxxx
xooxox
xoxxxx
6 3
o.x.x.
oo.o.x
xx.oo.
.x.xx.
ooxo..
.xxo..
6 6
xoo..o
o.xx.x
oooooo
xx.x..
o..xx.
...xxx
6 5
xooxoo
ooxxoo
xxooxx
oxooxx
oxoxxx
xxoxoo
6 5
xoxxxo
ooooxo
ooxoxx
oxxoox
xxxxox
ooooxo
6 5
o....o
.ox.oo
...

output:

TAK
1 6
1 1
2 2
1 3
2 4
1 4
3 1
2 1
3 2
2 6
3 3
4 4
3 6
5 3
4 1
5 4
4 5
5 5
5 6
6 4
6 1
6 5
6 3
3 4
NIE
TAK
1 3
1 1
1 5
2 1
2 6
2 2
3 1
2 4
3 2
3 4
4 2
3 5
4 4
5 1
4 5
5 2
6 2
5 4
6 3
6 4
5 3
NIE
TAK
1 1
1 2
1 4
1 3
2 3
1 5
2 4
1 6
3 1
2 1
3 2
2 2
3 5
2 5
3 6
2 6
4 2
3 3
4 5
3 4
4 6
4 1
5 2
4 3
5 4
...

result:

ok correct (10000 test cases)