Submission #1122414

#TimeUsernameProblemLanguageResultExecution timeMemory
1122414vjudge1timeismoney (balkan11_timeismoney)C++17
45 / 100
2075 ms65536 KiB
#include <iostream> #include <vector> #include <algorithm> #include <queue> #include <map> #include <set> #include <stack> #include <functional> #include <cmath> #include <numeric> #include <iomanip> #include <cassert> using namespace std; typedef long long ll; typedef long double ld; #define sz(x) (int)(x).size() #define all(x) begin(x), end(x) constexpr ll INF = 1e9; int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int n, m; cin >> n >> m; vector<pair<int, int>> edge(m); vector<ll> t(m); vector<ll> c(m); for(int i = 0; i < m; i++) { int x, y; cin >> x >> y >> t[i] >> c[i]; edge[i] = {x, y}; } pair<ll, ll> best{INF, INF}; vector<pair<int, int>> ans; vector<int> order(m); iota(all(order), 0); auto check = [&]() { vector<int> p(n); vector<int> size(n, 1); iota(all(p), 0); function<int(int)> getPar = [&](int a) { if(a == p[a]) return a; return p[a] = getPar(p[a]); }; auto merge = [&](int a, int b) { a = getPar(a); b = getPar(b); if(a == b) return false; if(size[a] < size[b]) swap(a, b); size[a] += size[b]; p[b] = a; return true; }; vector<pair<int, int>> take; pair<ll, ll> cost{0,0}; for(auto i : order) { auto [a,b] = edge[i]; if(merge(a,b)) { take.push_back({a, b}); cost.first += t[i]; cost.second += c[i]; } } if(cost.first*cost.second < best.first*best.second) { best = cost; ans = take; } return cost; }; auto sortLeft = [&](ll T, ll C) { sort(all(order), [&](int a, int b) { ll aVal = T*t[a]+C*c[a]; ll bVal = T*t[b]+C*c[b]; if(aVal == bVal) return t[a] < t[b]; return aVal < bVal; }); }; auto sortRight = [&](ll T, ll C) { sort(all(order), [&](int a, int b) { ll aVal = T*t[a]+C*c[a]; ll bVal = T*t[b]+C*c[b]; if(aVal == bVal) return c[a] < c[b]; return aVal < bVal; }); }; function<void(pair<ll, ll>, pair<ll, ll>)> search = [&](pair<ll, ll> left, pair<ll, ll> right) { if(left == right) return; pair<ll, ll> mid = {left.first+right.first, left.second+right.second}; ll g = gcd(mid.first, mid.second); mid.first /= g; mid.second /= g; sortLeft(mid.first, mid.second); auto res = check(); if(res == left || res == right) return; search(left, res); sortRight(mid.first, mid.second); res = check(); if(res == left || res == right) return; search(res, right); }; sortRight(1,0); auto left = check(); sortLeft(0,1); auto right = check(); search(left, right); cout << best.first << " " << best.second << "\n"; for(auto [a,b] : ans) cout << a << " " << b << "\n"; }
#Verdict Execution timeMemoryGrader output
Fetching results...