Submission #750791

# Submission time Handle Problem Language Result Execution time Memory
750791 2023-05-30T10:06:29 Z rxlfd314 Cyberland (APIO23_cyberland) C++17
40 / 100
212 ms 20808 KB
#include "cyberland.h"
#include <bits/stdc++.h>
using namespace std;

double solve(int N, int M, int K, int H, vector<int> x, vector<int> y, vector<int> c, vector<int> arr) {
	vector<pair<int, double>> adj[N];
	for (int i = 0; i < M; i++) {
		adj[x[i]].push_back({y[i], (double)c[i]});
		adj[y[i]].push_back({x[i], (double)c[i]});
	}
	
	bool useful[N] = {};
	queue<int> qu;
	qu.push(0);
	useful[0] = true;
	while (qu.size()) {
		int f = qu.front();
		qu.pop();
		if (f == H) continue;
		for (auto [nf, _] : adj[f]) {
			if (!useful[nf]) {
				useful[nf] = true;
				qu.push(nf);
			}
		}
	}
	
	vector<vector<double>> dst(min(K, 80)+1, vector<double>(N, 1e14));
	double ans = 1e14;
	for (int ii = 0; ii <= min(K, 80); ii++) {
		priority_queue<pair<double, int>, vector<pair<double, int>>, greater<pair<double, int>>> pq;
		for (int i = 0; i < N; i++) {
			if (!useful[i]) continue;
			if (arr[i] == 2 && ii) {
				for (auto [j, v] : adj[i]) {
					if (!useful[j] || j == H) continue;
					dst[ii][i] = min(dst[ii][i], (dst[ii-1][j] + v) / 2.0);
				}
				pq.push({dst[ii][i], i});
			} else if (!arr[i]) {
				dst[ii][i] = 0;
				pq.push({0, i});
			}
		}
		if (!ii) {
			dst[0][0] = 0;
			pq.push({0, 0});
		}
		
		while (pq.size()) {
			auto [d, f] = pq.top();
			pq.pop();
			if (f == H) continue;
			for (auto [nf, v] : adj[f]) {
				if (d + v < dst[ii][nf] && useful[nf]) {
					dst[ii][nf] = d + v;
					pq.push({d+v, nf});
				}
			}
		}
		
		ans = min(ans, dst[ii][H]);
	}
	
	return ans;
}
# Verdict Execution time Memory Grader output
1 Incorrect 34 ms 460 KB Wrong Answer.
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 26 ms 752 KB Correct.
2 Correct 31 ms 772 KB Correct.
3 Correct 29 ms 704 KB Correct.
4 Correct 30 ms 692 KB Correct.
5 Correct 30 ms 668 KB Correct.
6 Correct 28 ms 3712 KB Correct.
7 Correct 37 ms 3684 KB Correct.
8 Correct 16 ms 7324 KB Correct.
9 Correct 31 ms 500 KB Correct.
10 Correct 28 ms 488 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 146 ms 692 KB Correct.
2 Correct 157 ms 764 KB Correct.
3 Correct 131 ms 768 KB Correct.
4 Correct 98 ms 480 KB Correct.
5 Correct 93 ms 480 KB Correct.
6 Correct 40 ms 3364 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 96 ms 20808 KB Correct.
2 Correct 92 ms 684 KB Correct.
3 Correct 81 ms 744 KB Correct.
4 Correct 89 ms 752 KB Correct.
5 Correct 63 ms 468 KB Correct.
# Verdict Execution time Memory Grader output
1 Incorrect 27 ms 708 KB Wrong Answer.
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 93 ms 712 KB Wrong Answer.
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 101 ms 636 KB Wrong Answer.
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 212 ms 1064 KB Wrong Answer.
2 Halted 0 ms 0 KB -