結果
問題 | No.1301 Strange Graph Shortest Path |
ユーザー | fura |
提出日時 | 2020-11-29 17:43:43 |
言語 | C++17(gcc12) (gcc 12.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 272 ms / 3,000 ms |
コード長 | 2,398 bytes |
コンパイル時間 | 2,378 ms |
コンパイル使用メモリ | 215,684 KB |
実行使用メモリ | 34,576 KB |
最終ジャッジ日時 | 2024-09-13 02:02:06 |
合計ジャッジ時間 | 10,589 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
6,816 KB |
testcase_01 | AC | 2 ms
6,940 KB |
testcase_02 | AC | 215 ms
32,960 KB |
testcase_03 | AC | 172 ms
29,400 KB |
testcase_04 | AC | 197 ms
31,232 KB |
testcase_05 | AC | 178 ms
32,364 KB |
testcase_06 | AC | 175 ms
29,284 KB |
testcase_07 | AC | 211 ms
30,700 KB |
testcase_08 | AC | 170 ms
29,708 KB |
testcase_09 | AC | 199 ms
27,776 KB |
testcase_10 | AC | 177 ms
29,316 KB |
testcase_11 | AC | 183 ms
30,064 KB |
testcase_12 | AC | 226 ms
30,168 KB |
testcase_13 | AC | 205 ms
33,136 KB |
testcase_14 | AC | 207 ms
27,964 KB |
testcase_15 | AC | 199 ms
28,876 KB |
testcase_16 | AC | 200 ms
31,200 KB |
testcase_17 | AC | 179 ms
33,328 KB |
testcase_18 | AC | 192 ms
30,268 KB |
testcase_19 | AC | 217 ms
29,312 KB |
testcase_20 | AC | 173 ms
28,288 KB |
testcase_21 | AC | 217 ms
31,772 KB |
testcase_22 | AC | 178 ms
29,056 KB |
testcase_23 | AC | 207 ms
33,232 KB |
testcase_24 | AC | 175 ms
28,928 KB |
testcase_25 | AC | 243 ms
31,424 KB |
testcase_26 | AC | 216 ms
30,240 KB |
testcase_27 | AC | 228 ms
30,372 KB |
testcase_28 | AC | 185 ms
32,836 KB |
testcase_29 | AC | 244 ms
30,592 KB |
testcase_30 | AC | 231 ms
31,148 KB |
testcase_31 | AC | 230 ms
30,720 KB |
testcase_32 | AC | 2 ms
6,944 KB |
testcase_33 | AC | 114 ms
27,020 KB |
testcase_34 | AC | 272 ms
34,576 KB |
ソースコード
#include <bits/stdc++.h> #define rep(i,n) for(int i=0;i<(n);i++) using namespace std; using lint=long long; template<class capa_t,class cost_t> class mcf_graph{ struct edge{ int to,rev; capa_t capa,flow; cost_t cost; edge(int to,int rev,const capa_t& capa,const cost_t& cost,const capa_t& flow):to(to),rev(rev),capa(capa),cost(cost),flow(flow){} }; vector<vector<edge>> G; static constexpr capa_t CAPA_INF=numeric_limits<capa_t>::max(); static constexpr cost_t COST_INF=numeric_limits<cost_t>::max(); public: mcf_graph(){} mcf_graph(int n):G(n){} void add_directed_edge(int u,int v,const capa_t& capa,const cost_t& cost){ G[u].emplace_back(v,G[v].size() ,capa, cost,0); G[v].emplace_back(u,G[u].size()-1, 0,-cost,0); } pair<capa_t,cost_t> minimum_cost_flow(int s,int t){ int n=G.size(); vector<int> pre(n); vector<cost_t> d(n),pot(n); auto augment=[&]()->pair<capa_t,cost_t>{ rep(u,n) d[u]=(u==s?0:COST_INF); // Dijkstra bool ok=false; priority_queue<pair<cost_t,int>> Q; Q.emplace(0,s); while(!Q.empty()){ int u=Q.top().second; cost_t cost=-Q.top().first; Q.pop(); if(cost<d[u]) continue; if(u==t) ok=true; for(const edge& e:G[u]) if(e.capa-e.flow>0) { cost_t cost2=cost+e.cost+pot[u]-pot[e.to]; if(cost2<d[e.to]){ d[e.to]=cost2; pre[e.to]=e.rev; Q.emplace(-cost2,e.to); } } } if(!ok) return {0,0}; capa_t water=CAPA_INF; for(int u=t;u!=s;){ edge& e1=G[u][pre[u]]; edge& e2=G[e1.to][e1.rev]; water=min(water,e2.capa-e2.flow); u=e1.to; } cost_t cost=0; for(int u=t;u!=s;){ edge& e1=G[u][pre[u]]; edge& e2=G[e1.to][e1.rev]; e1.flow-=water; e2.flow+=water; cost+=water*e2.cost; u=e1.to; } rep(u,n) pot[u]+=d[u]; return {water,cost}; }; capa_t res1=0; cost_t res2=0; while(1){ auto tmp=augment(); if(tmp.first==0) break; res1+=tmp.first; res2+=tmp.second; } return make_pair(res1,res2); } }; int main(){ int n,m; scanf("%d%d",&n,&m); mcf_graph<int,lint> G(n+1); rep(i,m){ int u,v; lint c1,c2; scanf("%d%d%lld%lld",&u,&v,&c1,&c2); u--; v--; G.add_directed_edge(u,v,1,c1); G.add_directed_edge(u,v,1,c2); G.add_directed_edge(v,u,1,c1); G.add_directed_edge(v,u,1,c2); } G.add_directed_edge(n-1,n,2,0); printf("%lld\n",G.minimum_cost_flow(0,n).second); return 0; }