제출 #532610

#제출 시각아이디문제언어결과실행 시간메모리
532610amunduzbaevOlympic Bus (JOI20_ho_t4)C++17
0 / 100
255 ms2532 KiB
#include "bits/stdc++.h" using namespace std; #define ar array const int N = 205, M = 5e4 + 5; vector<ar<int, 3>> edges[N]; int a[M], b[M], c[M], p[M]; int d[N], par[N], T[N][N]; signed main(){ ios::sync_with_stdio(0); cin.tie(0); int n, m; cin>>n>>m; for(int i=0;i<N;i++){ for(int j=0;j<N;j++){ T[i][j] = 1e9; } T[i][i] = 0; } for(int i=0;i<m;i++){ cin>>a[i]>>b[i]>>c[i]>>p[i]; edges[a[i]].push_back({b[i], c[i], i}); T[a[i]][b[i]] = min(T[a[i]][b[i]], c[i]); } for(int k=1;k<=n;k++){ for(int i=1;i<=n;i++){ for(int j=1;j<=n;j++){ T[i][j] = min(T[i][j], T[i][k] + T[k][j]); } } } vector<int> tot; auto djk = [&](int u){ priority_queue<ar<int, 2>, vector<ar<int, 2>>, greater<ar<int, 2>>> q; q.push({0, u}); for(int i=1;i<=n;i++) d[i] = 1e9; memset(par, -1, sizeof par); d[u] = 0; while(!q.empty()){ int u = q.top()[1], D = q.top()[0]; q.pop(); if(D > d[u]) continue; for(auto x : edges[u]){ if(d[x[0]] > d[u] + x[1]){ par[x[0]] = x[2]; d[x[0]] = d[u] + x[1]; q.push({d[x[0]], x[0]}); } } } vector<int> tt; for(int i=1;i<=n;i++){ if(~par[i]) tt.push_back(par[i]); } tot.insert(tot.end(), tt.begin(), tt.end()); }; //~ const int inf = 2e9; //~ auto bashka = [&](int t, int u){ //~ priority_queue<ar<int, 2>, vector<ar<int, 2>>, greater<ar<int, 2>>> q; //~ q.push({0, u}); //~ vector<ar<int, 2>> d(n + 1, {inf, inf}); //~ memset(par, -1, sizeof par); //~ d[u][0] = 0; //~ while(!q.empty()){ //~ int u = q.top()[1], D = q.top()[0]; q.pop(); //~ if(u <= n){ //~ if(D > d[u][0]) continue; //~ for(auto x : edges[t][u]){ //~ if(d[x[0]][0] > d[u][0] + x[1]){ //~ d[x[0]][0] = d[u][0] + x[1]; //~ q.push({d[x[0]][0], x[0]}); //~ } //~ } //~ for(auto x : edges[t^1][u]){ //~ if(d[x[0]][1] > d[u][0] + x[1]){ //~ d[x[0]][1] = d[u][0] + x[1]; //~ q.push({d[x[0]][1], x[0] + n}); //~ } //~ } //~ } else { //~ } //~ } //~ vector<int> tt; //~ for(int i=1;i<=n;i++){ //~ if(~par[i]) tt.push_back(par[i]); //~ } return tt; //~ }; ar<int, 2> D {}; djk(1), D[0] = d[n]; djk(n), D[1] = d[1]; int res = D[0] + D[1]; auto check = [&](int in){ swap(a[in], b[in]); for(int i=1;i<=n;i++) edges[i].clear(); for(int i=0;i<m;i++){ edges[a[i]].push_back({b[i], c[i], -1}); } int D = 0; djk(1), D += d[n]; djk(n), D += d[1]; res = min(res, D + p[in]); swap(a[in], b[in]); }; sort(tot.begin(), tot.end()); tot.erase(unique(tot.begin(), tot.end()), tot.end()); vector<int> is(m); for(auto x : tot){ check(x); is[x] = 1; } for(int i=0;i<m;i++){ if(is[i]) continue; int st = min(T[1][b[i]] + T[a[i]][n] + c[i], D[0]), ts = min(T[n][b[i]] + c[i] + T[a[i]][1], D[1]); res = min(res, st + ts + p[i]); } if(res >= 2e9) cout<<-1<<"\n"; else cout<<res<<"\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...