結果
| 問題 |
No.649 ここでちょっとQK!
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2019-10-12 15:50:54 |
| 言語 | Nim (2.2.0) |
| 結果 |
AC
|
| 実行時間 | 36 ms / 3,000 ms |
| コード長 | 2,763 bytes |
| コンパイル時間 | 4,196 ms |
| コンパイル使用メモリ | 61,528 KB |
| 実行使用メモリ | 6,784 KB |
| 最終ジャッジ日時 | 2024-11-28 01:37:53 |
| 合計ジャッジ時間 | 7,169 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 32 |
コンパイルメッセージ
/home/judge/data/code/Main.nim(2, 8) Warning: imported and not used: 'sequtils' [UnusedImport]
ソースコード
{.checks:off.}
import sequtils
template times*(n:int,body) = (for _ in 0..<n: body)
proc printf(formatstr: cstring){.header: "<stdio.h>", varargs.}
proc getchar_unlocked():char {. importc:"getchar_unlocked",header: "<stdio.h>" .}
proc scan(): int =
while true:
let k = getchar_unlocked()
if k < '0': return
result = 10 * result + k.ord - '0'.ord
template useBinaryHeap() =
type
BinaryHeap*[T] = object
nodes: seq[T]
compare: proc(x,y:T):int
popchunk: bool
proc newBinaryHeap*[T](compare:proc(x,y:T):int): BinaryHeap[T] =
BinaryHeap[T](nodes:newSeq[T](),compare:compare,popchunk:false)
proc compareNode[T](h:BinaryHeap[T],i,j:int):int = h.compare(h.nodes[i],h.nodes[j])
proc size*[T](h:BinaryHeap[T]):int = h.nodes.len() - h.popchunk.int
proc items*[T](h:var BinaryHeap[T]):seq[T] =
if h.popchunk : discard h.popimpl()
return h.nodes
proc top*[T](h:var BinaryHeap[T]): T =
if h.popchunk : discard h.popimpl()
return h.nodes[0]
proc push*[T](h:var BinaryHeap[T],node:T):void =
if h.popchunk :
h.nodes[0] = node
h.shiftdown()
else: h.pushimpl(node)
proc pop*[T](h:var BinaryHeap[T]):T =
if h.popchunk: discard h.popimpl()
h.popchunk = true
return h.nodes[0]
proc shiftdown[T](h:var BinaryHeap[T]): void =
h.popchunk = false
let size = h.nodes.len()
var i = 0
while true :
let L = i * 2 + 1
let R = i * 2 + 2
if L >= size : break
let child = if R < size and h.compareNode(R,L) <= 0 : R else: L
if h.compareNode(i,child) <= 0: break
swap(h.nodes[i],h.nodes[child])
i = child
proc pushimpl[T](h:var BinaryHeap[T],node:T):void =
h.nodes.add(node) #末尾に追加
var i = h.nodes.len() - 1
while i > 0: # 末尾から木を整形
let parent = (i - 1) div 2
if h.compare(h.nodes[parent],node) <= 0: break
h.nodes[i] = h.nodes[parent]
i = parent
h.nodes[i] = node
proc popimpl[T](h:var BinaryHeap[T]):T =
result = h.nodes[0] # rootと末尾を入れ替えて木を整形
h.nodes[0] = h.nodes[^1]
h.nodes.setLen(h.nodes.len() - 1)
h.shiftdown()
useBinaryHeap()
let q = scan()
let k = scan()
var less = newBinaryHeap[int](proc(x,y:int):int = -x+y)
var greater = newBinaryHeap[int](proc(x,y:int):int = -y+x)
q.times:
if less.size() > 0 : discard less.top()
if greater.size() > 0 : discard greater.top()
if scan() == 1:
let v = scan()
if less.size() < k : less.push(v)
else:
if v < less.top() :
greater.push(less.pop())
less.push(v)
else: greater.push(v)
else:
if less.size() < k : printf("-1\n")
else:
printf("%ld\n",less.pop())
if greater.size() > 0 : less.push(greater.pop())