結果
| 問題 |
No.1768 The frog in the well knows the great ocean.
|
| コンテスト | |
| ユーザー |
tomerun
|
| 提出日時 | 2021-11-26 23:48:22 |
| 言語 | Crystal (1.14.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,915 bytes |
| コンパイル時間 | 10,891 ms |
| コンパイル使用メモリ | 295,032 KB |
| 実行使用メモリ | 26,848 KB |
| 最終ジャッジ日時 | 2024-06-29 19:08:30 |
| 合計ジャッジ時間 | 14,292 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 25 WA * 2 |
ソースコード
read_line.to_i.times do
puts solve() ? "Yes" : "No"
end
def solve
n = read_line.to_i
a = read_line.split.map(&.to_i)
b = read_line.split.map(&.to_i)
c = Array.new(n, false)
set = Set(Int32).new
q = PriorityQueue(Int32).new(n)
n.times do |i|
if a[i] > b[i]
return false
end
set << a[i]
q.add(a[i])
while q.size > 0 && q.top > b[i]
set.delete(q.top)
q.pop
end
c[i] ||= set.includes?(b[i])
end
set.clear
q.clear
(n - 1).downto(0) do |i|
set << a[i]
q.add(a[i])
while q.size > 0 && q.top > b[i]
set.delete(q.top)
q.pop
end
c[i] ||= set.includes?(b[i])
end
return c.all? { |v| v }
end
class PriorityQueue(T)
def initialize(capacity : Int32)
@elem = Array(T).new(capacity)
end
def initialize(list : Enumerable(T))
@elem = list.to_a
1.upto(size - 1) { |i| fixup(i) }
end
def size
@elem.size
end
def add(v)
@elem << v
fixup(size - 1)
end
def top
@elem[0]
end
def pop
ret = @elem[0]
last = @elem.pop
if size > 0
@elem[0] = last
fixdown(0)
end
ret
end
def clear
@elem.clear
end
def decrease_top(new_value : T)
@elem[0] = new_value
fixdown(0)
end
def to_s(io : IO)
io << @elem
end
private def fixup(index : Int32)
while index > 0
parent = (index - 1) // 2
break if @elem[parent] >= @elem[index]
@elem[parent], @elem[index] = @elem[index], @elem[parent]
index = parent
end
end
private def fixdown(index : Int32)
while true
left = index * 2 + 1
break if left >= size
right = index * 2 + 2
child = right >= size || @elem[left] > @elem[right] ? left : right
if @elem[child] > @elem[index]
@elem[child], @elem[index] = @elem[index], @elem[child]
index = child
else
break
end
end
end
end
tomerun