QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#514014#9170. Cycle Gameucup-team4504#WA 0ms3828kbC++171.8kb2024-08-10 21:07:532024-08-10 21:07:54

Judging History

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

  • [2024-08-10 21:07:54]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:3828kb
  • [2024-08-10 21:07:53]
  • 提交

answer

#include <bits/stdc++.h>
#define endl '\n'
using namespace std;
const int N = 1e6 + 5;
int n, m, q;
bool vis[N];
int V, E, F, C;
int fa[N]; int getfa(int x){return x == fa[x] ? x : fa[x] = getfa(fa[x]);}
int getid(int x, int y){
	return x * (m + 2) + y;
}
void update(int x, int y, int k){
	V += k * vis[getid(x, y)];
	E += k * (vis[getid(x, y)] && vis[getid(x - 1, y)]);
	E += k * (vis[getid(x, y)] && vis[getid(x, y - 1)]);
	E += k * (vis[getid(x, y)] && vis[getid(x + 1, y)]);
	E += k * (vis[getid(x, y)] && vis[getid(x, y + 1)]);
	int p[9] = {getid(x - 1, y - 1), getid(x - 1, y), getid(x - 1, y + 1), getid(x, y - 1), getid(x, y), getid(x, y + 1), getid(x + 1, y - 1), getid(x + 1, y), getid(x + 1, y + 1)};
	for (int i = 0; i < 9; i++) p[i] = vis[p[i]];
	F += k * p[0] * p[1] * p[3] * p[4];
	F += k * p[1] * p[2] * p[4] * p[5];
	F += k * p[3] * p[4] * p[6] * p[7];
	F += k * p[4] * p[5] * p[7] * p[8];
}
int main(){
	ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);
//	freopen("in.txt", "r", stdin);
//	freopen("out.txt", "w", stdout);
	cin >> n >> m >> q;
	for (int i = 0; i < (n + 2) * (m + 2); i++) fa[i] = i;
	while (q--){
		int x, y;
		cin >> x >> y;
		if (vis[getid(x, y)]){
			putchar('1');
			continue;
		}
		update(x, y, -1);
		vis[getid(x, y)] = 1;
		C++;
		update(x, y, 1);
		int p[5] = {getid(x - 1, y), getid(x, y - 1), getid(x + 1, y), getid(x, y + 1), getid(x, y)};
		set<int> st;
		for (int id : p)
			if (vis[id])
				st.insert(getfa(id));
		if (V - E + F != C - (int)st.size() + 1){
			putchar('0');
			update(x, y, -1);
			vis[getid(x, y)] = 0;
			C--;
			update(x, y, 1);
		}else{
			putchar('1');
			C += 1 - (int)st.size();
			for (int id : st)
				fa[getfa(id)] = getfa(getid(x, y));
		}
	}
	return 0;
}

详细

Test #1:

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

input:

4 3 7
2 1
2 2
2 3
3 1
3 2
4 1
4 2

output:

1111111

result:

ok "1111111"

Test #2:

score: 0
Accepted
time: 0ms
memory: 3604kb

input:

3 3 8
1 1
1 2
1 3
2 3
3 3
3 2
3 1
2 1

output:

11111110

result:

ok "11111110"

Test #3:

score: 0
Accepted
time: 0ms
memory: 3616kb

input:

10 10 7
9 1
6 6
3 8
8 7
5 10
1 7
1 2

output:

1111111

result:

ok "1111111"

Test #4:

score: 0
Accepted
time: 0ms
memory: 3616kb

input:

9 10 50
1 9
1 6
2 3
3 1
7 4
9 4
1 3
2 5
9 2
7 9
5 6
8 10
9 5
5 5
4 10
9 7
5 9
3 2
4 5
1 1
4 7
3 6
2 8
4 3
8 6
5 10
4 8
5 4
7 2
9 6
4 2
7 8
5 2
3 5
9 1
6 1
1 5
9 9
5 8
6 3
8 8
8 4
7 7
7 1
3 7
2 2
3 10
6 9
8 3
7 6

output:

11111111111111111111111111111111111111111111111111

result:

ok "11111111111111111111111111111111111111111111111111"

Test #5:

score: 0
Accepted
time: 0ms
memory: 3604kb

input:

3 5 11
1 5
2 4
1 2
1 3
3 3
3 1
3 4
2 3
1 4
2 1
2 5

output:

11111111111

result:

ok "11111111111"

Test #6:

score: 0
Accepted
time: 0ms
memory: 3828kb

input:

7 9 12
7 3
2 3
6 2
2 2
4 2
2 8
5 7
4 4
6 8
2 7
7 2
1 9

output:

111111111111

result:

ok "111111111111"

Test #7:

score: 0
Accepted
time: 0ms
memory: 3604kb

input:

1 4 1
1 2

output:

1

result:

ok "1"

Test #8:

score: -100
Wrong Answer
time: 0ms
memory: 3784kb

input:

9 8 67
5 5
8 3
9 5
7 4
5 1
9 3
4 2
2 5
1 7
7 8
7 2
8 5
6 1
8 8
4 4
5 4
1 5
3 4
6 7
2 3
3 7
5 7
2 4
2 7
1 3
7 3
2 8
6 6
6 2
6 3
7 5
9 6
7 6
3 6
1 1
6 4
3 1
5 3
8 7
2 1
4 1
8 4
8 6
3 5
5 8
1 6
1 2
4 6
9 4
1 4
3 3
4 8
8 1
4 7
9 8
3 8
6 5
6 8
3 2
2 2
7 1
9 2
4 3
1 8
4 5
8 2
7 7

output:

1111111111111111111111111111111111111111111110011111101010001101111

result:

wrong answer 1st words differ - expected: '111111111111111111111111111111...1111111110010101101000101101101', found: '111111111111111111111111111111...1111111110011111101010001101111'