Submission #1461345


Source Code Expand

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;
using llng = long long;
template<typename T> using v = vector<T>;
template<typename T> using vv = v<v<T> >;

struct Edge {
    int to, cap, rev;
    Edge(int _t, int _c, int _r) : to(_t), cap(_c), rev(_r) {}
};

struct Graph {
    vv<Edge> edge;
    Graph(int N) { edge = vv<Edge>(N); }
    void add(int from, int to, int cap) { add_edge(from, to, cap, false); }
    void add_ud(int v1, int v2, int cap) { add_edge(v1, v2, cap, true); }
private:
    void add_edge(int v1, int v2, int cap, bool isUd) {
        int v1_rev = edge[v2].size();
        int v2_rev = edge[v1].size();
        edge[v1].push_back(Edge(v2, cap, v1_rev));
        edge[v2].push_back(Edge(v1, (isUd ? cap : 0), v2_rev));
    }
};

class FF {
    Graph g;
    v<bool> used;
    int ff_dfs(int v, int t, int f) {
        if (v == t) return f;
        used[v] = true;
        for (Edge &e : g.edge[v]) if (!used[e.to] && e.cap > 0) {
            int d = ff_dfs(e.to, t, min(f, e.cap));
            if (d > 0) {
                e.cap -= d; g.edge[e.to][e.rev].cap += d;
                return d;
            }
        }
        return 0;
    }
public:
    FF(Graph _g) : g(_g) {}
    int run(int s, int t) {
        int fl = 0;
        while (true) {
            used = v<bool>(g.edge.size());
            int f = ff_dfs(s, t, 1e9);
            if (f == 0) return fl;
            fl += f;
        }
    }
};

int main() {
    int N, G, E; cin >> N >> G >> E;
    Graph g(N+1);
    for (int i=0; i<G; i++) { int p; cin >> p; g.add(p, N, 1); }
    for (int i=0; i<E; i++) { int a, b; cin >> a >> b; g.add_ud(a, b, 1); }
    cout << FF(g).run(0, N) << endl;
    return 0;
}

Submission Info

Submission Time
Task D - 浮気予防
User hidollara
Language C++14 (GCC 5.4.1)
Score 100
Code Size 1784 Byte
Status AC
Exec Time 3 ms
Memory 640 KB

Judge Result

Set Name part All
Score / Max Score 99 / 99 1 / 1
Status
AC × 27
AC × 61
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, 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 1 ms 256 KB
sample_02.txt AC 1 ms 256 KB
sample_03.txt AC 1 ms 256 KB
sample_04.txt AC 1 ms 256 KB
sample_05.txt AC 1 ms 256 KB
test_01_AB.txt AC 1 ms 256 KB
test_02_AB.txt AC 1 ms 256 KB
test_03_AB.txt AC 1 ms 256 KB
test_04_AB.txt AC 1 ms 256 KB
test_05_AB.txt AC 1 ms 256 KB
test_06_AB.txt AC 1 ms 256 KB
test_07_AB.txt AC 1 ms 256 KB
test_08_AB.txt AC 1 ms 256 KB
test_09_AB.txt AC 1 ms 256 KB
test_10_AB.txt AC 1 ms 256 KB
test_11_AB.txt AC 1 ms 256 KB
test_12_AB.txt AC 1 ms 256 KB
test_13_AB.txt AC 1 ms 256 KB
test_14_AB.txt AC 1 ms 256 KB
test_15_AB.txt AC 1 ms 256 KB
test_16_AB.txt AC 1 ms 256 KB
test_17_AB.txt AC 1 ms 256 KB
test_18_AB.txt AC 1 ms 256 KB
test_19_AB.txt AC 1 ms 256 KB
test_20_AB.txt AC 1 ms 256 KB
test_21_AB.txt AC 1 ms 256 KB
test_22_AB.txt AC 1 ms 256 KB
test_23_AB.txt AC 1 ms 256 KB
test_24_AB.txt AC 1 ms 256 KB
test_25_AB.txt AC 1 ms 256 KB
test_26_A.txt AC 3 ms 640 KB
test_27_A.txt AC 3 ms 640 KB
test_28_A.txt AC 3 ms 640 KB
test_29_A.txt AC 3 ms 640 KB
test_30_A.txt AC 3 ms 640 KB
test_31_A.txt AC 3 ms 640 KB
test_32_A.txt AC 2 ms 256 KB
test_33_A.txt AC 2 ms 384 KB
test_34_A.txt AC 1 ms 256 KB
test_35_A.txt AC 2 ms 384 KB
test_36_A.txt AC 1 ms 256 KB
test_37_A.txt AC 2 ms 384 KB
test_38_A.txt AC 1 ms 256 KB
test_39_A.txt AC 1 ms 256 KB
test_40_A.txt AC 1 ms 256 KB
test_41_AB.txt AC 1 ms 256 KB
test_42_A.txt AC 2 ms 384 KB
test_43_A.txt AC 1 ms 256 KB
test_44_A.txt AC 2 ms 384 KB
test_45_A.txt AC 1 ms 256 KB
test_46_A.txt AC 1 ms 256 KB
test_47_AB.txt AC 1 ms 256 KB
test_48_A.txt AC 1 ms 256 KB
test_49_A.txt AC 1 ms 256 KB
test_50_A.txt AC 1 ms 256 KB
test_51_A.txt AC 1 ms 256 KB