結果

問題 No.277 根掘り葉掘り
ユーザー TANIGUCHI Kousuke
提出日時 2015-09-09 09:25:20
言語 Ruby
(3.4.1)
結果
TLE  
実行時間 -
コード長 653 bytes
コンパイル時間 82 ms
コンパイル使用メモリ 7,424 KB
実行使用メモリ 17,664 KB
最終ジャッジ日時 2024-07-19 05:02:09
合計ジャッジ時間 5,582 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 5 TLE * 1 -- * 12
権限があれば一括ダウンロードができます
コンパイルメッセージ
Main.rb:8: warning: assigned but unused variable - from
Main.rb:8: warning: assigned but unused variable - to
Syntax OK

ソースコード

diff #

# Here your code !
INF = 10 ** 8
n = gets.to_i
P = Array.new(n+1,1); P[0] = 1; 
R = Array.new(n+1,INF); R[0] = 0; R[1] = 0
L = Array.new(n+1,INF); L[0] = 0;

E = (n - 1).times.map { from, to = gets.split.map(&:to_i) }.group_by {|from,to| from }
(1..n).each do |from|
    if E[from]
        E[from].each do |(_,to)|
            P[to] = from
            R[to] = R[from] + 1
        end
    end
end

leaf = (1..n).reject {|v| E[v] }
leaf.each do |i|
    d = R[i] + 1
    d.times.inject(i) do |j, dep|
        L[j] = [L[j], dep].min
        P[j]
    end
end

(1..n).each do |i|
  L[i] = [ L[i], L[P[i]] + 1].min
end

puts (1..n).map {|i| [R[i], L[i]].min }
0