Submission #750779

# Submission time Handle Problem Language Result Execution time Memory
750779 2023-05-30T09:44:26 Z rxlfd314 Cyberland (APIO23_cyberland) C++17
21 / 100
526 ms 20864 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], c[i]});
		adj[y[i]].push_back({x[i], 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>> pq;
		for (int i = 0; i < N && ii; i++) {
			if (!useful[i]) continue;
			if (arr[i] == 2) {
				for (auto [j, v] : adj[i]) {
					if (!useful[j]) 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 (d > dst[ii][f]) 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 39 ms 468 KB Wrong Answer.
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 24 ms 764 KB Correct.
2 Correct 30 ms 756 KB Correct.
3 Correct 27 ms 676 KB Correct.
4 Correct 31 ms 652 KB Correct.
5 Correct 28 ms 720 KB Correct.
6 Correct 28 ms 3736 KB Correct.
7 Correct 33 ms 3708 KB Correct.
8 Correct 14 ms 7392 KB Correct.
9 Correct 27 ms 504 KB Correct.
10 Correct 28 ms 504 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 262 ms 652 KB Correct.
2 Correct 211 ms 732 KB Correct.
3 Correct 190 ms 768 KB Correct.
4 Correct 126 ms 468 KB Correct.
5 Correct 120 ms 468 KB Correct.
6 Correct 49 ms 3156 KB Correct.
# Verdict Execution time Memory Grader output
1 Correct 107 ms 20864 KB Correct.
2 Incorrect 120 ms 756 KB Wrong Answer.
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 107 ms 696 KB Wrong Answer.
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 320 ms 892 KB Wrong Answer.
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 272 ms 672 KB Wrong Answer.
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Incorrect 526 ms 1156 KB Wrong Answer.
2 Halted 0 ms 0 KB -