Submission #525919

#TimeUsernameProblemLanguageResultExecution timeMemory
525919JosiaPaths (RMI21_paths)C++14
36 / 100
1068 ms21772 KiB
#include <bits/stdc++.h> using namespace std; #define int int64_t vector<pair<int, int>> parents; vector<vector<pair<int, int>>> graph; vector<int> order; int n, k; void generateParents(int v, int p, int weight) { if (parents[v].first != -1) return; parents[v].first = p; parents[v].second = weight; for (auto u: graph[v]) { if (parents[u.first].first != -1) continue; generateParents(u.first, v, u.second); } order.push_back(v); } int stl(int v) { vector<multiset<int>> tree(n, {0}); // offset, options vector<int> pointers; for (int i = 0; i<n; i++) pointers.push_back(i); order.pop_back(); for (int i: order) { int newElem = *tree[pointers[i]].rbegin() + parents[i].second; tree[pointers[i]].erase(*tree[pointers[i]].rbegin()); tree[pointers[i]].insert(newElem); if (tree[pointers[i]].size() > tree[pointers[parents[i].first]].size()) { swap(pointers[i], pointers[parents[i].first]); } auto it = tree[pointers[i]].begin(); while (it != tree[pointers[i]].end()) { tree[pointers[parents[i].first]].insert(*it); it++; } while (tree[pointers[parents[i].first]].size() > k) { tree[pointers[parents[i].first]].erase(tree[pointers[parents[i].first]].begin()); } } // cerr << "root element: "; // for (int i: tree[pointers[v]]) { // cerr << i << " "; // } cerr << "\n"; int res = 0; auto it = tree[pointers[v]].end(); for (int i = 0; i<k; i++) { it--; res += *it; } return res; } void solve() { cin >> n >> k; graph.resize(n); for (int i = 0; i<n-1; i++) { int a, b, c; cin >> a >> b >> c; a--; b--; graph[a].push_back({b, c}); graph[b].push_back({a, c}); } for (int i = 0; i<n; i++) { // cerr << i << " ----------------------\n"; parents.clear(); parents.assign(n, {-1, 0}); order.clear(); generateParents(i, -2, 0); // cerr << "order: "; // for (auto i: order) { // cerr << i << " "; // } cerr << "\n"; // cerr << "parents: "; // for (auto i: parents) { // cerr << i.first << " "; // } cerr << "\n"; assert(order.back() == i); int res = stl(i); cout << res << "\n"; // cerr << "result: " << res << "\n"; } } signed main() { cin.tie(0); ios_base::sync_with_stdio(0); solve(); return 0; }

Compilation message (stderr)

Main.cpp: In function 'int64_t stl(int64_t)':
Main.cpp:54:56: warning: comparison of integer expressions of different signedness: 'std::multiset<long int>::size_type' {aka 'long unsigned int'} and 'int64_t' {aka 'long int'} [-Wsign-compare]
   54 |         while (tree[pointers[parents[i].first]].size() > k) {
      |                ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...