QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#576838#9345. Artful Paintingslqh2024TL 362ms3844kbC++201.8kb2024-09-19 22:50:112024-09-19 22:50:11

Judging History

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

  • [2024-09-19 22:50:11]
  • 评测
  • 测评结果:TL
  • 用时:362ms
  • 内存:3844kb
  • [2024-09-19 22:50:11]
  • 提交

answer

#include <bits/stdc++.h>
#define int long long
using namespace std;

void solve() {
	int n, m1, m2;
	cin >> n >> m1 >> m2;

	vector<array<int, 3>> a(m1 + m2 + 1);
	for (int i = 1; i <= m1 + m2; i++) {
		cin >> a[i][0] >> a[i][1] >> a[i][2];
	}

	auto check = [&](int v) -> bool {
		int s = n + 1;
		vector<vector<pair<int, int>>> adj(n + 2);
		for (int i = 1; i <= m1 + m2; i++) {
			auto [l, r, k] = a[i];
			if (i <= m1) {
				//s[l - 1] - s[r] <= -k

				adj[r].push_back({l - 1, -k});
			} else {
				//s[r] - s[l - 1] <= v - k
				adj[l - 1].push_back({r, v - k});
			}
		}
		for (int i = 1; i <= n; i++) {
			adj[s].push_back({i, 0});
		}
		// s[i] - s[0] <= min(i, v)
		for (int i = 1; i <= n; i++) {
			adj[0].push_back({i, min(i, v)});
		}
		// s[i] - s[i - 1] <= 1
		// s[i - 1] - s[i] <= 0
		for (int i = 1; i <= n; i++) {
			adj[i - 1].push_back({i, 1});
			adj[i].push_back({i - 1, 0});
		}

		auto spfa = [&]() -> bool {
			vector<int> dis(n + 2, 1e9), vis(n + 2), inq(n + 2);
			dis[s] = 0;	
			vis[s] = 1;
			queue<int> q;
			q.push(s);
			while (q.size()) {
				int u = q.front();
				q.pop();
				vis[u] = 0;
				inq[u]++;
				if (inq[u] > 2 * n) return false;
				for (auto [v, w] : adj[u]) {
					if (dis[u] + w < dis[v]) {
						dis[v] = dis[u] + w;
						if (!vis[v]) {
							vis[v] = 1;
							q.push(v);
						}
					}
				}
			}
			return true;
		};

		return spfa();
	};

	int L = 0, R = n, ans = n;
	while (L <= R) {
		int mid = (L + R) / 2;
		if (check(mid)) {	
			ans = mid;
			R = mid - 1;
		} else {
			L = mid + 1;
		}
	}

	cout << ans << "\n";
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    
    int T;
    cin >> T;
    while (T--) solve();

    return 0;
}

详细

Test #1:

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

input:

1
3 1 1
1 2 1
2 2 1

output:

1

result:

ok single line: '1'

Test #2:

score: 0
Accepted
time: 362ms
memory: 3844kb

input:

1
1000 500 500
479 860 170
73 939 25
363 772 30
185 584 89
326 482 10
784 949 23
384 740 114
233 693 45
167 724 211
217 436 95
46 701 153
138 585 67
321 388 11
114 890 194
407 854 74
438 845 117
9 718 259
393 576 35
182 707 257
451 766 136
150 382 31
468 785 40
202 490 46
326 815 59
272 441 77
123 8...

output:

492

result:

ok single line: '492'

Test #3:

score: -100
Time Limit Exceeded

input:

1
3000 1000 1000
497 660 17
36 1021 195
2363 2786 90
1202 1218 5
1443 1627 76
2398 2642 59
1614 2082 296
2241 2286 3
360 2995 1736
2163 2566 245
526 990 103
916 1774 392
523 762 38
140 1912 187
472 2868 33
945 1039 60
739 2666 99
865 1440 143
1603 2378 97
672 1202 322
75 1406 367
1483 2534 397
1875 ...

output:


result: