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