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
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 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