結果

問題 No.654 Air E869120
ユーザー yuto1115yuto1115
提出日時 2020-05-08 23:27:42
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 75 ms / 2,000 ms
コード長 3,493 bytes
コンパイル時間 2,231 ms
コンパイル使用メモリ 217,484 KB
実行使用メモリ 5,416 KB
最終ジャッジ日時 2023-09-17 03:31:09
合計ジャッジ時間 4,663 ms
ジャッジサーバーID
(参考情報)
judge15 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,376 KB
testcase_01 AC 1 ms
4,380 KB
testcase_02 AC 1 ms
4,376 KB
testcase_03 AC 1 ms
4,376 KB
testcase_04 AC 2 ms
4,376 KB
testcase_05 AC 1 ms
4,376 KB
testcase_06 AC 1 ms
4,376 KB
testcase_07 AC 1 ms
4,380 KB
testcase_08 AC 1 ms
4,376 KB
testcase_09 AC 1 ms
4,376 KB
testcase_10 AC 75 ms
5,416 KB
testcase_11 AC 40 ms
4,848 KB
testcase_12 AC 62 ms
4,952 KB
testcase_13 AC 61 ms
4,980 KB
testcase_14 AC 39 ms
4,784 KB
testcase_15 AC 53 ms
5,348 KB
testcase_16 AC 5 ms
4,380 KB
testcase_17 AC 5 ms
4,376 KB
testcase_18 AC 5 ms
4,380 KB
testcase_19 AC 5 ms
4,376 KB
testcase_20 AC 3 ms
4,376 KB
testcase_21 AC 3 ms
4,380 KB
testcase_22 AC 2 ms
4,380 KB
testcase_23 AC 3 ms
4,380 KB
testcase_24 AC 3 ms
4,376 KB
testcase_25 AC 2 ms
4,376 KB
testcase_26 AC 3 ms
4,380 KB
testcase_27 AC 2 ms
4,380 KB
testcase_28 AC 2 ms
4,380 KB
testcase_29 AC 3 ms
4,380 KB
testcase_30 AC 2 ms
4,376 KB
testcase_31 AC 2 ms
4,376 KB
testcase_32 AC 2 ms
4,380 KB
testcase_33 AC 2 ms
4,380 KB
testcase_34 AC 2 ms
4,376 KB
testcase_35 AC 1 ms
4,380 KB
testcase_36 AC 1 ms
4,376 KB
testcase_37 AC 1 ms
4,376 KB
testcase_38 AC 1 ms
4,380 KB
testcase_39 AC 1 ms
4,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>
#define rep(i,n) for (int i = 0; i < (n); ++i)
#define rrep(i,n) for (int i = (n)-1; i >= 0; i--)
#define rep2(i,s,n) for (int i = (s); i < (n); ++i)
#define all(a) a.begin(),a.end()
#define rall(a) a.rbegin(),a.rend()
#define pb push_back
#define eb emplace_back
#define vi vector<int>
#define vvi vector<vector<int>>
#define vl vector<ll>
#define vvl vector<vector<ll>>
#define vs vector<string>
#define vc vector<char>
#define vb vector<bool>
#define vp vector<P>
using namespace std;
using ll = long long;
using P = pair<int,int>;
using LP = pair<ll,ll>;
template<class T> istream& operator>>(istream& is,vector<T>& v) { for(T& t:v){is>>t;} return is; }
template<class T> ostream& operator<<(ostream& os,const vector<T>& v) { for(T t:v){os<<t<<" ";} os<<"\n"; return os; }
void Yes(bool b) { cout << (b ? "Yes" : "No") << endl; }
void YES(bool b) { cout << (b ? "YES" : "NO") << endl; }
template<class T> inline bool chmin(T& a,T b) {if(a > b){a = b; return true;} return false;}
template<class T> inline bool chmax(T& a,T b) {if(a < b){a = b; return true;} return false;}
const int inf = 1001001001;
const ll linf = 1001001001001001001;

class flow {
    struct edge {
        int to,rev;
        ll cap;
        edge(int to,ll cap,int rev):to(to),cap(cap),rev(rev) {}
    };
    int n;
    vector<vector<edge>> G;
    vi level,iter;

    void bfs(int s) {
        level.assign(n,-1);
        queue<int> q;
        level[s] = 0;
        q.push(s);
        while(!q.empty()) {
            int v = q.front();
            q.pop();
            for(auto& e : G[v]) {
                if(e.cap > 0 && level[e.to] < 0) {
                    level[e.to] = level[v]+1;
                    q.push(e.to);
                }
            }
        }
    }
    ll dfs(int v,int t,ll f) {
        if(v == t) return f;
        rep2(i,iter[v],G[v].size()) {
            auto &e = G[v][i];
            if(e.cap > 0 && level[v] < level[e.to]) {
                ll d = dfs(e.to,t,min(f,e.cap));
                if(d > 0) {
                    e.cap -= d;
                    G[e.to][e.rev].cap += d;
                    return d;
                }
            }
        }
        return 0;
    }

public:
    explicit flow(int n):n(n),G(n),level(n),iter(n) {}
    void add_edge(int from,int to,ll cap) {
        G[from].eb(to,cap,G[to].size());
        G[to].eb(from,0,G[from].size()-1);
    }
    // O(|E||V|^2) dinic-algorithm
    ll max_flow(int s,int t) {
        ll fl = 0;
        while(true) {
            bfs(s);
            if(level[t] < 0) return fl;
            iter.assign(n,0);
            ll f;
            while((f = dfs(s,t,inf)) > 0) fl += f;
        }
    }
};

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr); cout.tie(nullptr);
    int n,m,d;
    cin >> n >> m >> d;
    flow fl(2*m+2);
    int ind = 0;
    // time,index
    vector<vp> in(n),out(n);
    rep(_,m) {
        int u,v,p,q,w;
        cin >> u >> v >> p >> q >> w;
        u--; v--;
        out[u].eb(p,ind);
        in[v].eb(q,ind+1);
        fl.add_edge(ind,ind+1,w);
        ind += 2;
    }
    rep(i,n) {
        for(auto p : in[i]) {
            for(auto q : out[i]) {
                if(p.first+d <= q.first) {
                    fl.add_edge(p.second,q.second,linf);
                }
            }
        }
    }
    for(auto p : out[0]) fl.add_edge(ind,p.second,linf);
    for(auto p : in[n-1]) fl.add_edge(p.second,ind+1,linf);
    cout << fl.max_flow(ind,ind+1) << endl;
}
0