Submission #180966


Source Code Expand

#include <vector>
#include <iostream>
#include <set>
#include <cstdio>
#include <queue>
#include <cstdio>
#include <cstdlib>
#include <cassert>
#include <ctime>
#include <algorithm>
#include <tuple>
#include <algorithm>
#include <limits>
#include <map>

using namespace std;

const int MAX_V = 200;
const int INT_INF = 1<<28;
struct edge {int to, cap, rev;};

vector<edge> G[MAX_V];
int level[MAX_V];
int iter[MAX_V];

void add_edge(int from, int to, int cap) {
    G[from].push_back((edge){to, cap, (int)G[to].size()});
    G[to].push_back((edge){from, 0, (int)G[from].size()-1});
}

void add_edge_multi(int from, int to, int cap) {
    G[from].push_back((edge){to, cap, (int)G[to].size()});
    G[to].push_back((edge){from, cap, (int)G[from].size()-1});
}

void bfs(int s) {
    fill_n(level, MAX_V, -1);
    queue<int> que;
    level[s] = 0;
    que.push(s);
    while (!que.empty()) {
        int v = que.front(); que.pop();
        for (int i = 0; i < G[v].size(); i++) {
            edge &e = G[v][i];
            if (e.cap > 0 && level[e.to] < 0) {
                level[e.to] = level[v] + 1;
                que.push(e.to);
            }
        }
    }
}

int dfs (int v, int t, int f) {
    if (v == t) return f;
    for (int &i = iter[v]; i < G[v].size(); i++) {
        edge &e = G[v][i];
        if (e.cap > 0 && level[v] < level[e.to]) {
            int 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;
}

int max_flow(int s, int t) {
    int flow = 0;
    while (true) {
        bfs(s);
        if (level[t] < 0) return flow;
        fill_n(iter, MAX_V, 0);
        int f;
        while ((f = dfs(s, t, INT_INF)) > 0) {
            flow += f;
        }
    }
}

int main() {
    int n, g, e;
    cin >> n >> g >> e;
    for (int i = 0; i < g; i++) {
        int d;
        cin >> d;
        add_edge_multi(d, 190, 1);
    }
    for (int i = 0; i < e; i++) {
        int a, b;
        cin >> a >> b;
        add_edge_multi(a, b, 1);
    }
    cout << max_flow(0, 190) << endl;
    return 0;
}

Submission Info

Submission Time
Task D - 浮気予防
User yosupo
Language C++11 (GCC 4.8.1)
Score 100
Code Size 2252 Byte
Status AC
Exec Time 37 ms
Memory 1044 KB

Judge Result

Set Name part All
Score / Max Score 99 / 99 1 / 1
Status
AC × 27
AC × 56
Set Name Test Cases
part test_01_AB.txt, test_02_AB.txt, test_03_AB.txt, test_04_AB.txt, test_05_AB.txt, test_06_AB.txt, test_07_AB.txt, test_08_AB.txt, test_09_AB.txt, test_10_AB.txt, test_11_AB.txt, test_12_AB.txt, test_13_AB.txt, test_14_AB.txt, test_15_AB.txt, test_16_AB.txt, test_17_AB.txt, test_18_AB.txt, test_19_AB.txt, test_20_AB.txt, test_21_AB.txt, test_22_AB.txt, test_23_AB.txt, test_24_AB.txt, test_25_AB.txt, test_41_AB.txt, test_47_AB.txt
All sample_01.txt, sample_02.txt, sample_03.txt, sample_04.txt, sample_05.txt, test_01_AB.txt, test_02_AB.txt, test_03_AB.txt, test_04_AB.txt, test_05_AB.txt, test_06_AB.txt, test_07_AB.txt, test_08_AB.txt, test_09_AB.txt, test_10_AB.txt, test_11_AB.txt, test_12_AB.txt, test_13_AB.txt, test_14_AB.txt, test_15_AB.txt, test_16_AB.txt, test_17_AB.txt, test_18_AB.txt, test_19_AB.txt, test_20_AB.txt, test_21_AB.txt, test_22_AB.txt, test_23_AB.txt, test_24_AB.txt, test_25_AB.txt, test_26_A.txt, test_27_A.txt, test_28_A.txt, test_29_A.txt, test_30_A.txt, test_31_A.txt, test_32_A.txt, test_33_A.txt, test_34_A.txt, test_35_A.txt, test_36_A.txt, test_37_A.txt, test_38_A.txt, test_39_A.txt, test_40_A.txt, test_41_AB.txt, test_42_A.txt, test_43_A.txt, test_44_A.txt, test_45_A.txt, test_46_A.txt, test_47_AB.txt, test_48_A.txt, test_49_A.txt, test_50_A.txt, test_51_A.txt
Case Name Status Exec Time Memory
sample_01.txt AC 37 ms 800 KB
sample_02.txt AC 21 ms 912 KB
sample_03.txt AC 22 ms 916 KB
sample_04.txt AC 22 ms 868 KB
sample_05.txt AC 21 ms 916 KB
test_01_AB.txt AC 24 ms 844 KB
test_02_AB.txt AC 23 ms 840 KB
test_03_AB.txt AC 24 ms 924 KB
test_04_AB.txt AC 22 ms 924 KB
test_05_AB.txt AC 22 ms 732 KB
test_06_AB.txt AC 23 ms 920 KB
test_07_AB.txt AC 22 ms 736 KB
test_08_AB.txt AC 21 ms 920 KB
test_09_AB.txt AC 23 ms 872 KB
test_10_AB.txt AC 21 ms 924 KB
test_11_AB.txt AC 22 ms 864 KB
test_12_AB.txt AC 22 ms 924 KB
test_13_AB.txt AC 22 ms 920 KB
test_14_AB.txt AC 22 ms 840 KB
test_15_AB.txt AC 23 ms 920 KB
test_16_AB.txt AC 24 ms 908 KB
test_17_AB.txt AC 22 ms 916 KB
test_18_AB.txt AC 21 ms 924 KB
test_19_AB.txt AC 23 ms 872 KB
test_20_AB.txt AC 23 ms 924 KB
test_21_AB.txt AC 22 ms 728 KB
test_22_AB.txt AC 23 ms 920 KB
test_23_AB.txt AC 21 ms 924 KB
test_24_AB.txt AC 21 ms 916 KB
test_25_AB.txt AC 23 ms 796 KB
test_26_A.txt AC 27 ms 976 KB
test_27_A.txt AC 28 ms 1040 KB
test_28_A.txt AC 25 ms 1040 KB
test_29_A.txt AC 25 ms 996 KB
test_30_A.txt AC 25 ms 1044 KB
test_31_A.txt AC 26 ms 1016 KB
test_32_A.txt AC 23 ms 884 KB
test_33_A.txt AC 24 ms 920 KB
test_34_A.txt AC 24 ms 936 KB
test_35_A.txt AC 24 ms 968 KB
test_36_A.txt AC 24 ms 948 KB
test_37_A.txt AC 26 ms 884 KB
test_38_A.txt AC 22 ms 840 KB
test_39_A.txt AC 22 ms 868 KB
test_40_A.txt AC 21 ms 920 KB
test_41_AB.txt AC 23 ms 920 KB
test_42_A.txt AC 26 ms 920 KB
test_43_A.txt AC 23 ms 920 KB
test_44_A.txt AC 20 ms 916 KB
test_45_A.txt AC 22 ms 920 KB
test_46_A.txt AC 24 ms 932 KB
test_47_AB.txt AC 22 ms 920 KB
test_48_A.txt AC 22 ms 860 KB
test_49_A.txt AC 24 ms 864 KB
test_50_A.txt AC 24 ms 888 KB
test_51_A.txt AC 22 ms 924 KB