Submission #329998

#TimeUsernameProblemLanguageResultExecution timeMemory
329998EndRayProgramming Contest (POI11_pro)C++17
30 / 100
1094 ms876 KiB
#include<bits/stdc++.h> using namespace std; const int N = 500+1; int n, m, r, t, k; vector<int> g[N]; int mt[N], d[N]; bool used[N]; bool try_dfs(int v, int deg){ if(used[v]) return false; used[v] = true; if(d[v] > deg+1) return true; for(int u : g[v]) if(mt[u] != -1 && try_dfs(mt[u], deg)){ --d[mt[u]]; mt[u] = v; ++d[v]; return true; } return false; } int main(){ ios_base::sync_with_stdio(false); cout.tie(0); cin.tie(0); cin >> n >> m >> r >> t >> k; for(int i = 0; i < k; ++i){ int u, v; cin >> u >> v; --u; --v; g[u].push_back(v); } for(int u = 0; u < m; ++u) mt[u] = -1; for(int v = 0; v < n; ++v) for(int u : g[v]) if(mt[u] == -1){ mt[u] = v; ++d[v]; } bool updated = true; while(updated){ updated = false; for(int v = 0; v < n; ++v){ for(int i = 0; i < n; ++i) used[i] = false; if(try_dfs(v, d[v])){ updated = true; break; } } } int penalty = 0; vector<tuple<int, int, int>> res; for(int v = 0; v < n; ++v) d[v] = min(d[v], t/r); for(int u = 0; u < m; ++u) if(mt[u] != -1 && d[mt[u]]){ penalty += d[mt[u]]*r; --d[mt[u]]; res.emplace_back(mt[u]+1, u+1, d[mt[u]]*r); } cout << res.size() << " " << penalty << "\n"; for(auto el : res) cout << get<0>(el) << " " << get<1>(el) << " " << get<2>(el) << "\n"; }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...