QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#234898#5509. Kooky Tic-Tac-Toeraztun#AC ✓22ms3672kbC++203.6kb2023-11-02 01:47:032023-11-02 01:47:03

Judging History

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

  • [2023-11-02 01:47:03]
  • 评测
  • 测评结果:AC
  • 用时:22ms
  • 内存:3672kb
  • [2023-11-02 01:47:03]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;
char tab[10][10];
int w[10][10];
int main()
{
	ios_base::sync_with_stdio(false);
	cin.tie(NULL);
	int zz; cin>>zz;
	while (zz--)
	{
		int n, k; cin>>n>>k;
		int a=0, b=0, mx=0, whx=-1, why=-1;
		vector<pair<int, int>>xx, oo;
		for (int i=0; i<n; i++)
		{
			for (int j=0; j<n; j++)
			{
				cin>>tab[i][j];
				if (tab[i][j]=='x') xx.push_back({i, j}), a++;
				if (tab[i][j]=='o') oo.push_back({i, j}), b++;
				w[i][j]=0;
			}
		}
		if (abs(a-b) > 1)
		{
			cout<<"NIE\n";
			continue;
		}
		int wa=0, wb=0;
		for (int i=0; i<n; i++)
		{
			for (int j=0; j<n; j++)
			{
				if (tab[i][j]=='.') continue;
				
				int x=i, y=j, cnt=0;
				while (cnt<k && x>=0 && tab[i][j]==tab[x][y]) x--, cnt++;
				if (cnt==k)
				{
					wa+=tab[i][j]=='x';
					wb+=tab[i][j]=='o';
					x=i; y=j;
					while (cnt>0 && x>=0) w[x][y]++, x--, cnt--;
				}
				
				x=i; y=j; cnt=0;
				while (cnt<k && y>=0 && tab[i][j]==tab[x][y]) y--, cnt++;
				if (cnt==k)
				{
					wa+=tab[i][j]=='x';
					wb+=tab[i][j]=='o';
					x=i; y=j;
					while (cnt>0 && y>=0) w[x][y]++, y--, cnt--;
				}
				
				x=i; y=j; cnt=0;
				while (cnt<k && x>=0 && y>=0 && tab[i][j]==tab[x][y]) x--, y--, cnt++;
				if (cnt==k)
				{
					wa+=tab[i][j]=='x';
					wb+=tab[i][j]=='o';
					x=i; y=j;
					while (cnt>0 && x>=0 && y>=0) w[x][y]++, x--, y--, cnt--;
				}
				
				x=i; y=j; cnt=0;
				while (cnt<k && x>=0 && y<n && tab[i][j]==tab[x][y]) x--, y++, cnt++;
				if (cnt==k)
				{
					wa+=tab[i][j]=='x';
					wb+=tab[i][j]=='o';
					x=i; y=j;
					while (cnt>0 && x>=0 && y<n) w[x][y]++, x--, y++, cnt--;
				}
			}
		}
		for (int i=0; i<n; i++) for (int j=0; j<n; j++) if (w[i][j]>mx) {mx=w[i][j], whx=i, why=j;}
		
		if ((!wa && !wb && a+b<n*n) || (wa && wb) || (wa && a<b) || (wb && b<a))
		{
			cout<<"NIE\n";
			continue;
		}
		
		int kto=((a>b || (a==b && wb))? 1 : 2);
		
		tab[whx][why]='.';
		wa=wb=0;
		for (int i=0; i<n; i++)
		{
			for (int j=0; j<n; j++)
			{
				if (tab[i][j]=='.') continue;
				int na=0, nb=0;
				int x=i, y=j, cnt=0;
				while (x>=0 && tab[i][j]==tab[x][y]) x--, cnt++;
				na+=(cnt>=k && tab[i][j]=='x');
				nb+=(cnt>=k && tab[i][j]=='o');
				
				x=i; y=j; cnt=0;
				while (y>=0 && tab[i][j]==tab[x][y]) y--, cnt++;
				na+=(cnt>=k && tab[i][j]=='x');
				nb+=(cnt>=k && tab[i][j]=='o');
				
				x=i; y=j; cnt=0;
				while (x>=0 && y>=0 && tab[i][j]==tab[x][y]) x--, y--, cnt++;
				na+=(cnt>=k && tab[i][j]=='x');
				nb+=(cnt>=k && tab[i][j]=='o');
				
				x=i; y=j; cnt=0;
				while (x>=0 && y<n && tab[i][j]==tab[x][y]) x--, y++, cnt++;
				na+=(cnt>=k && tab[i][j]=='x');
				nb+=(cnt>=k && tab[i][j]=='o');
				
				w[i][j]=na+nb;
				
				if (w[i][j] >= mx)
				{
					mx=w[i][j];
					whx=i;
					why=j;
				}
				
				wa+=na;
				wb+=nb;
			}
		}
		
		if (wa || wb)
		{
			cout<<"NIE\n";
			continue;
		}
		
		cout<<"TAK\n";
		while (xx.size() || oo.size())
		{
			//~ cout<<zz<<" "<<xx.size()<<" "<<oo.size()<<endl;
			if (kto == 1)
			{
				if (xx.back().first==whx && xx.back().second==why)
				{
					swap(xx[0], xx.back());
				}
				cout<<xx.back().first+1<<" "<<xx.back().second+1<<"\n";
				xx.pop_back();
				kto=2;
			}
			else if (kto == 2)
			{
				if (oo.back().first==whx && oo.back().second==why)
				{
					swap(oo[0], oo.back());
				}
				cout<<oo.back().first+1<<" "<<oo.back().second+1<<"\n";
				oo.pop_back();
				kto=1;
			}
		}
	}
}
//~ 1 
//~ 4 3
//~ xxxx
//~ o.o.
//~ ....
//~ o.o.

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3596kb

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
2 3
3 3
2 2
3 1
1 1
1 3
2 1
TAK
1 4
4 2
1 2
3 3
1 1
2 4
TAK
1 2
3 1
3 2
2 3
2 1
2 2
1 3
1 1
3 3
NIE
NIE
NIE
NIE

result:

ok correct (7 test cases)

Test #2:

score: 0
Accepted
time: 8ms
memory: 3672kb

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
2 3
3 3
2 2
3 1
1 1
1 3
2 1
TAK
1 2
3 1
3 2
2 3
2 1
2 2
1 3
1 1
3 3
NIE
NIE
NIE
NIE
NIE
TAK
3 2
1 3
3 1
1 2
2 2
1 1
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
NIE
TAK
3 2
4 3
3 1
4 2
2 4
1 1
2 3
2 2
1 3
1 4
1 2
4 1
NIE
NIE
NIE
NIE
NIE
TAK
4 4
4 3
4 1
4 2
3 4
3 2
3 3
2 2
3 1
1 4
...

result:

ok correct (10000 test cases)

Test #3:

score: 0
Accepted
time: 22ms
memory: 3600kb

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
6 3
6 5
6 1
6 4
5 6
5 5
4 5
5 4
4 1
5 3
3 6
4 4
3 3
1 1
3 2
2 6
3 1
2 1
2 4
1 4
2 2
1 3
1 6
3 4
NIE
TAK
6 3
6 4
6 2
5 4
1 3
5 2
4 5
5 1
4 4
3 5
4 2
3 4
3 2
2 4
3 1
2 2
2 6
2 1
1 5
1 1
5 3
NIE
TAK
1 2
6 4
6 5
6 2
6 3
6 1
5 3
5 6
5 1
5 5
4 4
5 4
4 3
5 2
4 1
4 6
3 4
4 5
3 3
4 2
2 6
3 6
2 5
3 5
2 2
...

result:

ok correct (10000 test cases)