Submission #2417043
Source Code Expand
# 行先, 容量, 逆辺 Edge = Struct.new(:to, :cap, :rev) # Ford-Fulkerson 法で最大流を解く class FordFulkerson def initialize(n) @G = Array.new(n){[]} # グラフの隣接リスト表現 @used = Array.new(n) # DFS で既に調べたか end # from -> to へ向かう容量 cap の辺をグラフに追加 def add_edge(from, to, cap) @G[from] << Edge.new(to, cap, @G[to].size) @G[to] << Edge.new(from, 0, @G[from].size - 1) end # 増加パスを DFS で探索 def dfs(v, t, f) return f if v == t @used[v] = true @G[v].each do |e| if !@used[e.to] && e.cap > 0 d = dfs(e.to, t, [f, e.cap].min) if d > 0 e.cap -= d @G[e.to][e.rev].cap += d return d end end end 0 end # s から t への最大流を計算 def max_flow(s, t) flow = 0 loop do @used.fill(false) f = dfs(s, t, Float::INFINITY) return flow if f == 0 flow += f end end end N, G, E = gets.split.map(&:to_i) p = gets.split.map(&:to_i) ab = Array.new(E) { gets.split.map(&:to_i) } S, T = 0, N ff = FordFulkerson.new(N+1) ab.each do |a, b| ff.add_edge(a, b, 1) ff.add_edge(b, a, 1) end p.each do |x| ff.add_edge(x, T, 1) end puts ff.max_flow(S, T)
Submission Info
Submission Time | |
---|---|
Task | D - 浮気予防 |
User | tfnw315 |
Language | Ruby (2.3.3) |
Score | 100 |
Code Size | 1349 Byte |
Status | AC |
Exec Time | 68 ms |
Memory | 4092 KB |
Judge Result
Set Name | part | All | ||||
---|---|---|---|---|---|---|
Score / Max Score | 99 / 99 | 1 / 1 | ||||
Status |
|
|
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 | 7 ms | 1788 KB |
sample_02.txt | AC | 7 ms | 1788 KB |
sample_03.txt | AC | 7 ms | 1788 KB |
sample_04.txt | AC | 7 ms | 1788 KB |
sample_05.txt | AC | 7 ms | 1788 KB |
test_01_AB.txt | AC | 7 ms | 1788 KB |
test_02_AB.txt | AC | 7 ms | 1788 KB |
test_03_AB.txt | AC | 7 ms | 1788 KB |
test_04_AB.txt | AC | 7 ms | 1788 KB |
test_05_AB.txt | AC | 7 ms | 1788 KB |
test_06_AB.txt | AC | 7 ms | 1788 KB |
test_07_AB.txt | AC | 7 ms | 1788 KB |
test_08_AB.txt | AC | 7 ms | 1788 KB |
test_09_AB.txt | AC | 7 ms | 1788 KB |
test_10_AB.txt | AC | 7 ms | 1788 KB |
test_11_AB.txt | AC | 7 ms | 1788 KB |
test_12_AB.txt | AC | 7 ms | 1788 KB |
test_13_AB.txt | AC | 7 ms | 1788 KB |
test_14_AB.txt | AC | 7 ms | 1788 KB |
test_15_AB.txt | AC | 7 ms | 1788 KB |
test_16_AB.txt | AC | 7 ms | 1788 KB |
test_17_AB.txt | AC | 7 ms | 1788 KB |
test_18_AB.txt | AC | 7 ms | 1788 KB |
test_19_AB.txt | AC | 7 ms | 1788 KB |
test_20_AB.txt | AC | 7 ms | 1788 KB |
test_21_AB.txt | AC | 7 ms | 1788 KB |
test_22_AB.txt | AC | 7 ms | 1788 KB |
test_23_AB.txt | AC | 7 ms | 1788 KB |
test_24_AB.txt | AC | 7 ms | 1788 KB |
test_25_AB.txt | AC | 7 ms | 1788 KB |
test_26_A.txt | AC | 68 ms | 4092 KB |
test_27_A.txt | AC | 58 ms | 4092 KB |
test_28_A.txt | AC | 53 ms | 3964 KB |
test_29_A.txt | AC | 43 ms | 3708 KB |
test_30_A.txt | AC | 29 ms | 3324 KB |
test_31_A.txt | AC | 48 ms | 4092 KB |
test_32_A.txt | AC | 11 ms | 2044 KB |
test_33_A.txt | AC | 18 ms | 2428 KB |
test_34_A.txt | AC | 10 ms | 1916 KB |
test_35_A.txt | AC | 14 ms | 2300 KB |
test_36_A.txt | AC | 13 ms | 2044 KB |
test_37_A.txt | AC | 22 ms | 2556 KB |
test_38_A.txt | AC | 7 ms | 1788 KB |
test_39_A.txt | AC | 7 ms | 1788 KB |
test_40_A.txt | AC | 7 ms | 1788 KB |
test_41_AB.txt | AC | 7 ms | 1788 KB |
test_42_A.txt | AC | 22 ms | 2428 KB |
test_43_A.txt | AC | 7 ms | 1788 KB |
test_44_A.txt | AC | 14 ms | 2300 KB |
test_45_A.txt | AC | 8 ms | 1788 KB |
test_46_A.txt | AC | 8 ms | 1788 KB |
test_47_AB.txt | AC | 7 ms | 1788 KB |
test_48_A.txt | AC | 8 ms | 1788 KB |
test_49_A.txt | AC | 8 ms | 1788 KB |
test_50_A.txt | AC | 7 ms | 1788 KB |
test_51_A.txt | AC | 7 ms | 1788 KB |