結果

問題 No.763 Noelちゃんと木遊び
ユーザー hytkxdhytkxd
提出日時 2024-05-13 17:55:40
言語 Ruby
(3.3.0)
結果
TLE  
実行時間 -
コード長 872 bytes
コンパイル時間 272 ms
コンパイル使用メモリ 7,680 KB
実行使用メモリ 105,968 KB
最終ジャッジ日時 2024-05-13 17:55:48
合計ジャッジ時間 8,019 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 TLE -
testcase_01 -- -
testcase_02 -- -
testcase_03 -- -
testcase_04 -- -
testcase_05 -- -
testcase_06 -- -
testcase_07 -- -
testcase_08 -- -
testcase_09 -- -
testcase_10 -- -
testcase_11 -- -
testcase_12 -- -
testcase_13 -- -
testcase_14 -- -
testcase_15 -- -
testcase_16 -- -
testcase_17 -- -
testcase_18 -- -
testcase_19 -- -
testcase_20 -- -
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

#!/usr/local/bin/ruby
class PlayWithNoel
  def initialize(*arg)
    @n,@uv, = arg
    @adj=Array.new(@n){Array.new}
    @uv.each{|u,v| @adj[u-1].push(v-1); @adj[v-1].push(u-1)}
    @match = Array.new(@n)
    @cover = Array.new(@n)
  end

  private
  def paint(st)
    rop = false
    @visited[st] = true
    @adj[st].each do |v|
      unless @visited[v]
        w = @match[v]
        if w.nil? || @visited[w].nil? && paint(w)
          rop, @match[st],@match[v] = true,v,st
          break
        end
      end
    end
    rop
  end

  public

  def ans
    r=0
    (0...@n).each do |i|
      unless @match[i]
        @visited = Array.new(@n)
        if paint(i)
          r+=1
        end
      end
    end
    @n-r
  end
end
### END: class PlayWithNoel
iod = STDIN
n = iod.gets.to_i
uv = Array.new(n-1){iod.gets.split.map &:to_i}
puts PlayWithNoel.new(n,uv).ans
exit 0
0