Submission #182228
Source Code Expand
class Graph MAX_FLOW = 1_000_000 attr_reader :vertices def initialize(n) @vertices = Array.new(n).map { |_| [] } end public def add_edge!(u, v, cap) edge = Edge.new(v, cap) edge_rev = Edge.new(u, 0) edge.match edge_rev edge_rev.match edge @vertices[u].push edge @vertices[v].push edge_rev end def dfs(from, to, flow) return flow if from == to @used[from] = true @vertices[from].each { |e| if not @used[e.to] and e.cap > 0 d = dfs(e.to, to, [flow, e.cap].min) if d > 0 e.cap -= d e.reverse.cap += d return d end end } 0 end def max_flow(from, to) flow = 0 loop { @used = Array.new(@vertices.size, false) f = dfs(from, to, MAX_FLOW) break if f == 0 flow += f } flow end end class Edge attr_reader :to, :cap, :reverse attr_writer :cap def initialize(to, cap) @to = to @cap = cap end def match(match_edge) @reverse = match_edge end end graph = Graph.new(110) n,_,e = gets.split.map(&:to_i) gets.split.map(&:to_i).map { |marked| graph.add_edge! marked,n,1 } (0...e).each { |_| a,b = gets.split.map(&:to_i) graph.add_edge! a,b,1 graph.add_edge! b,a,1 } puts graph.max_flow 0,n
Submission Info
Submission Time | |
---|---|
Task | D - 浮気予防 |
User | hamadu |
Language | Ruby (1.9.3) |
Score | 100 |
Code Size | 1360 Byte |
Status | AC |
Exec Time | 97 ms |
Memory | 5640 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, 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 | 57 ms | 4556 KB |
sample_02.txt | AC | 57 ms | 4428 KB |
sample_03.txt | AC | 57 ms | 4552 KB |
sample_04.txt | AC | 61 ms | 4492 KB |
sample_05.txt | AC | 57 ms | 4396 KB |
test_01_AB.txt | AC | 57 ms | 4492 KB |
test_02_AB.txt | AC | 59 ms | 4532 KB |
test_03_AB.txt | AC | 57 ms | 4392 KB |
test_04_AB.txt | AC | 56 ms | 4488 KB |
test_05_AB.txt | AC | 55 ms | 4488 KB |
test_06_AB.txt | AC | 58 ms | 4428 KB |
test_07_AB.txt | AC | 58 ms | 4488 KB |
test_08_AB.txt | AC | 55 ms | 4488 KB |
test_09_AB.txt | AC | 58 ms | 4420 KB |
test_10_AB.txt | AC | 56 ms | 4488 KB |
test_11_AB.txt | AC | 57 ms | 4484 KB |
test_12_AB.txt | AC | 59 ms | 4500 KB |
test_13_AB.txt | AC | 57 ms | 4424 KB |
test_14_AB.txt | AC | 58 ms | 4612 KB |
test_15_AB.txt | AC | 58 ms | 4400 KB |
test_16_AB.txt | AC | 60 ms | 4424 KB |
test_17_AB.txt | AC | 58 ms | 4560 KB |
test_18_AB.txt | AC | 57 ms | 4432 KB |
test_19_AB.txt | AC | 57 ms | 4392 KB |
test_20_AB.txt | AC | 55 ms | 4488 KB |
test_21_AB.txt | AC | 58 ms | 4488 KB |
test_22_AB.txt | AC | 56 ms | 4488 KB |
test_23_AB.txt | AC | 55 ms | 4484 KB |
test_24_AB.txt | AC | 55 ms | 4492 KB |
test_25_AB.txt | AC | 58 ms | 4552 KB |
test_26_A.txt | AC | 91 ms | 5516 KB |
test_27_A.txt | AC | 94 ms | 5640 KB |
test_28_A.txt | AC | 94 ms | 5512 KB |
test_29_A.txt | AC | 94 ms | 5516 KB |
test_30_A.txt | AC | 92 ms | 5548 KB |
test_31_A.txt | AC | 97 ms | 5512 KB |
test_32_A.txt | AC | 62 ms | 4420 KB |
test_33_A.txt | AC | 74 ms | 4876 KB |
test_34_A.txt | AC | 60 ms | 4556 KB |
test_35_A.txt | AC | 64 ms | 4488 KB |
test_36_A.txt | AC | 61 ms | 4488 KB |
test_37_A.txt | AC | 67 ms | 4836 KB |
test_38_A.txt | AC | 56 ms | 4488 KB |
test_39_A.txt | AC | 58 ms | 4428 KB |
test_40_A.txt | AC | 58 ms | 4560 KB |
test_41_AB.txt | AC | 58 ms | 4492 KB |
test_42_A.txt | AC | 72 ms | 4864 KB |
test_43_A.txt | AC | 58 ms | 4492 KB |
test_44_A.txt | AC | 64 ms | 4488 KB |
test_45_A.txt | AC | 58 ms | 4612 KB |
test_46_A.txt | AC | 58 ms | 4492 KB |
test_47_AB.txt | AC | 56 ms | 4492 KB |
test_48_A.txt | AC | 59 ms | 4432 KB |
test_49_A.txt | AC | 60 ms | 4512 KB |
test_50_A.txt | AC | 62 ms | 4492 KB |
test_51_A.txt | AC | 62 ms | 4492 KB |