QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#793173#9802. Light Up the GridRikka_TL 1ms3796kbC++203.3kb2024-11-29 17:28:242024-11-29 17:28:25

Judging History

你现在查看的是测评时间为 2024-11-29 17:28:25 的历史记录

  • [2024-11-29 22:58:31]
  • 管理员手动重测本题所有提交记录
  • 测评结果:TL
  • 用时:1ms
  • 内存:3916kb
  • [2024-11-29 17:28:25]
  • 评测
  • 测评结果:0
  • 用时:1ms
  • 内存:3796kb
  • [2024-11-29 17:28:24]
  • 提交

answer

#include<iostream>
#include<vector>
#include<queue>
#include<cmath>
#define ll long long
#define lowbit(x) ((x)&(-x))
using namespace std;
ll arr[4]{};
ll n;
vector<ll>sit;
vector<vector<ll>>val;
vector<vector<bool>>check;
ll small[2][2][2][2]{};
ll dp(ll done, ll less) {
	if (check[done][less]) {
		return val[done][less];
	}
	check[done][less] = true;
	ll answer = 1e18;
	ll memory = done;
	while (memory) {
		ll act = lowbit(memory);
		for (ll q = 0; q < 16; ++q) {
			ll del = log2(act);
			ll used = dp(done - act, q);
			ll changes = (sit[del] ^ 15 ^ q);
			used += small[bool(changes & 8)][bool(changes & 4)][bool(changes & 2)][bool(changes & 1)];
			ll now = changes ^ q;
			now ^= less;
			used += small[bool(now & 8)][bool(now & 4)][bool(now & 2)][bool(now & 1)];
			answer = min(used, answer);
		}
		memory -= act;
	}
	return val[done][less] = answer;
}
void solve() {
	bool flag = false;
	cin >> n;
	sit.clear();
	val.clear();
	check.clear();
	sit.resize(n);
	val.resize(pow(2, n), vector<ll>(16));
	check.resize(pow(2, n), vector<bool>(16));
	for (ll q = 0; q < 16; ++q) {
		check[0][q] = true;
		val[0][q] = small[bool(q & 8)][bool(q & 4)][bool(q & 2)][bool(q & 1)];
	}
	for (ll q = 0; q < n; ++q) {
		char _;
		cin >> _;
		if (_ - '0') {
			sit[q] |= 8;
		}
		cin >> _;
		if (_ - '0') {
			sit[q] |= 4;
		}
		cin >> _;
		if (_ - '0') {
			sit[q] |= 2;
		}
		cin >> _;
		if (_ - '0') {
			sit[q] |= 1;
		}
		if (sit[q] == 15) {
			flag = true;
		}
	}
	ll answer = 1e18;
	for (ll q = 0; q < 16; ++q) {
		answer = min(answer, dp((1ll << n) - 1, q));
	}
	cout << answer + flag * 2 * (min(min(arr[0], arr[1]), min(arr[2], arr[3]))) << endl;
}
int main() {
	ios::sync_with_stdio(0);
	cin.tie(nullptr);
	cout.tie(nullptr);
	ll t = 1;
	cin >> t;
	for (ll q = 0; q < 4; ++q) {
		cin >> arr[q];
	}
	for (ll a = 0; a < 2; ++a) {
		for (ll b = 0; b < 2; ++b) {
			for (ll c = 0; c < 2; ++c) {
				for (ll d = 0; d < 2; ++d) {
					small[a][b][c][d] = 1e18;
				}
			}
		}
	}
	small[0][0][0][0] = 0;
	for (ll q = 1; q < 512; ++q) {
		ll final[4]{};
		ll finalval = 0;
		if (q & 1) {
			finalval += arr[3];
			for (ll i = 0; i < 4; ++i) {
				final[i] ^= 1;
			}
		}
		if (q & 2) {
			finalval += arr[1];
			for (ll i = 0; i < 2; ++i) {
				final[i] ^= 1;
			}
		}
		if (q & 4) {
			finalval += arr[1];
			for (ll i = 2; i < 4; ++i) {
				final[i] ^= 1;
			}
		}
		if (q & 8) {
			finalval += arr[2];
			for (ll i = 0; i < 4; i += 2) {
				final[i] ^= 1;
			}
		}
		if (q & 16) {
			finalval += arr[2];
			for (ll i = 1; i < 4; i += 2) {
				final[i] ^= 1;
			}
		}
		if (q & 32) {
			finalval += arr[0];
			final[0] ^= 1;
		}
		if (q & 64) {
			finalval += arr[0];
			final[1] ^= 1;
		}
		if (q & 128) {
			finalval += arr[0];
			final[2] ^= 1;
		}
		if (q & 256) {
			finalval += arr[0];
			final[3] ^= 1;
		}
		small[final[0]][final[1]][final[2]][final[3]] = min(finalval, small[final[0]][final[1]][final[2]][final[3]]);
	}
	for (ll a = 0; a < 2; ++a) {
		for (ll b = 0; b < 2; ++b) {
			for (ll c = 0; c < 2; ++c) {
				for (ll d = 0; d < 2; ++d) {
					//cout << a << b << endl << c << d << endl << small[a][b][c][d] << endl;
				}
			}
		}
	}
	while (t--) {
		solve();
	}
}

详细

Test #1:

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

input:

2 1000 100 10 1
4
10
00

01
00

00
10

00
01
1
11
11

output:

1121
2

result:

ok 2 number(s): "1121 2"

Test #2:

score: 0
Accepted
time: 1ms
memory: 3792kb

input:

2 1 1 1 1
4
10
00

01
00

00
10

00
01
1
11
11

output:

5
2

result:

ok 2 number(s): "5 2"

Test #3:

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

input:

1 1000000 1000000 1000000 1000000
1
11
11

output:

2000000

result:

ok 1 number(s): "2000000"

Test #4:

score: -100
Time Limit Exceeded

input:

10000 8 2 7 8
8
00
01

00
11

00
10

11
11

10
10

01
10

01
00

10
11
8
11
01

11
00

01
10

11
11

00
01

01
01

01
00

11
10
9
00
00

01
01

10
11

00
01

11
10

11
00

11
11

00
11

01
10
9
11
11

10
00

11
00

11
01

00
10

01
11

00
01

01
01

10
01
11
00
01

01
01

10
10

00
11

11
11

11
10
...

output:

36
34
38
38
44
36
45
38
40
41
38
46
34
37
37
35
29
39
39
40
38
40
44
38
29
38
38
38
34
35
32
41
38
40
41
44
44
34
37
34
29
39
39
40
46
35
39
38
38
38
41
29
42
42
36
41
43
40
41
34
44
39
37
37
34
40
38
38
42
40
38
36
28
34
32
41
38
39
38
37
36
40

result: