結果
問題 | No.168 ものさし |
ユーザー | siman |
提出日時 | 2017-09-17 22:18:55 |
言語 | Ruby (3.4.1) |
結果 |
TLE
|
実行時間 | - |
コード長 | 2,954 bytes |
コンパイル時間 | 45 ms |
コンパイル使用メモリ | 7,552 KB |
実行使用メモリ | 38,592 KB |
最終ジャッジ日時 | 2024-11-08 01:59:52 |
合計ジャッジ時間 | 6,540 ms |
ジャッジサーバーID (参考情報) |
judge5 / 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 | -- | - |
testcase_21 | -- | - |
testcase_22 | -- | - |
コンパイルメッセージ
Main.rb:144: warning: assigned but unused variable - check_list Syntax OK
ソースコード
require 'bigdecimal' class UnionFind def initialize(n) @size = Array.new(n, 1) @parent = [] n.times do |i| @parent[i] = i end end def find(x) if @parent[x] == x x else @parent[x] = find(@parent[x]) end end def unite(x, y) x = find(x) y = find(y) return if x == y @parent[y] = x @size[x] += @size[y] end def same(x, y) find(x) == find(y) end def size(x) @size[find(x)] end end class PriorityQueue attr_reader :size def initialize(order: :asc) @size = 0 @nodes = [] @operator = (order == :asc) ? [:>, :<] : [:<, :>] end def empty? @size.zero? end def push(node) if @nodes[0].nil? @nodes[0] = node else index = size @nodes[index] = node loop { parent = (index-1)/2 if (@nodes[parent].last <=> node.last).public_send(@operator.first, 0) @nodes[index], @nodes[parent] = @nodes[parent], @nodes[index] index = parent break if index.zero? else break end } end @size += 1 end alias_method :<<, :push def pop node = @nodes.first @nodes[0], @nodes[size - 1] = @nodes[size - 1], nil index = 0 loop { left = 2*index+1 right = 2*index+2 if @nodes[left].nil? && @nodes[right].nil? break elsif @nodes[left] && @nodes[right] target = (@nodes[left].last <=> @nodes[right].last).public_send(@operator.last, 0) ? left : right if (@nodes[target].last <=> @nodes[index].last).public_send(@operator.last, 0) @nodes[index], @nodes[target] = @nodes[target], @nodes[index] index = target else break end elsif @nodes[left] if (@nodes[left].last <=> @nodes[index].last).public_send(@operator.last, 0) @nodes[index], @nodes[left] = @nodes[left], @nodes[index] index = left else break end elsif @nodes[right] if (@nodes[right].last <=> @nodes[index].last).public_send(@operator.last, 0) @nodes[index], @nodes[right] = @nodes[right], @nodes[index] index = right else break end end } @size -= 1 node.first end def top @nodes.first end end N = gets.to_i points = [] N.times do points << gets.chomp.split.map(&:to_i) end pque = PriorityQueue.new 0.upto(N-2) do |i| (i+1).upto(N-1) do |j| p1 = points[i] p2 = points[j] dist = BigDecimal((p1[0] - p2[0]) ** 2 + (p1[1] - p2[1]) ** 2).sqrt(10) pque.push([[i, j, dist], dist]) end end check_list = {} max_d = 0 uf = UnionFind.new(N) until pque.empty? i, j, dist = pque.pop if uf.find(i) != uf.find(j) uf.unite(i, j) max_d = [max_d, dist].max break if uf.find(0) == uf.find(N-1) end end if max_d % 10 == 0 puts max_d.to_i else puts 10 * (max_d.to_i / 10 + 1) end