結果
問題 | No.885 アマリクエリ |
ユーザー | へのく |
提出日時 | 2019-09-13 23:14:51 |
言語 | Kotlin (1.9.23) |
結果 |
AC
|
実行時間 | 1,190 ms / 2,000 ms |
コード長 | 2,870 bytes |
コンパイル時間 | 14,404 ms |
コンパイル使用メモリ | 463,464 KB |
実行使用メモリ | 100,548 KB |
最終ジャッジ日時 | 2024-07-04 10:25:21 |
合計ジャッジ時間 | 25,524 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 453 ms
63,840 KB |
testcase_01 | AC | 1,190 ms
96,360 KB |
testcase_02 | AC | 676 ms
80,052 KB |
testcase_03 | AC | 440 ms
65,832 KB |
testcase_04 | AC | 437 ms
65,976 KB |
testcase_05 | AC | 418 ms
63,520 KB |
testcase_06 | AC | 421 ms
61,084 KB |
testcase_07 | AC | 370 ms
62,936 KB |
testcase_08 | AC | 439 ms
62,880 KB |
testcase_09 | AC | 1,053 ms
100,548 KB |
testcase_10 | AC | 294 ms
53,196 KB |
testcase_11 | AC | 286 ms
52,828 KB |
testcase_12 | AC | 276 ms
53,076 KB |
testcase_13 | AC | 326 ms
54,204 KB |
testcase_14 | AC | 324 ms
54,320 KB |
testcase_15 | AC | 328 ms
54,332 KB |
testcase_16 | AC | 301 ms
53,472 KB |
testcase_17 | AC | 305 ms
53,316 KB |
testcase_18 | AC | 322 ms
53,560 KB |
testcase_19 | AC | 291 ms
53,340 KB |
testcase_20 | AC | 290 ms
53,420 KB |
testcase_21 | AC | 293 ms
53,268 KB |
コンパイルメッセージ
Main.kt:3:10: warning: parameter 'args' is never used fun main(args: Array<String>) = IO().exec { ^ Main.kt:64:22: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. if (b == '-'.toByte()) { ^ Main.kt:68:23: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. if (b !in '0'.toByte()..'9'.toByte()) { ^ Main.kt:68:37: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. if (b !in '0'.toByte()..'9'.toByte()) { ^ Main.kt:72:26: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. if (b in '0'.toByte()..'9'.toByte()) { ^ Main.kt:72:40: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. if (b in '0'.toByte()..'9'.toByte()) { ^ Main.kt:74:30: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. n += b - '0'.toByte() ^
ソースコード
import java.util.* fun main(args: Array<String>) = IO().exec { val n = int() val a = LongArray(n){long()} val q = int() val x = LongArray(q){long()} val tmap = TreeMap<Long, Int>() for (p in a) { tmap[p] = (tmap[p] ?: 0) + 1 } var sum = a.sum() for (r in x) { var key = r - 1 while (true) { val k = tmap.higherKey(key) ?: break val v = tmap[k]!! sum -= (k / r) * r * v tmap.remove(k) if (k % r != 0L) tmap[k % r] = (tmap[k % r] ?: 0) + v key = k } println(sum) } } // region template operator fun Int.iterator() = 0.until(this).iterator() class IO { val printable = 33..126 val buffer = ByteArray(1024) var ptr = 0 var buflen = 0 val out = java.io.PrintWriter(System.out) fun hasNextByte(): Boolean = if (ptr < buflen) true else { ptr = 0 buflen = System.`in`.read(buffer) buflen > 0 } fun readByte(): Byte = if (hasNextByte()) buffer[ptr++] else -1 fun hasNext(): Boolean { while (hasNextByte() && buffer[ptr] !in printable) ptr++ return hasNextByte() } fun string(): String { if (!hasNext()) throw java.util.NoSuchElementException() val sb = StringBuilder() var b = readByte() while (b in printable) { sb.appendCodePoint(b.toInt()) b = readByte() } return sb.toString() } fun long(): Long { if (!hasNext()) throw java.util.NoSuchElementException() var n = 0L var minus = false var b = readByte() if (b == '-'.toByte()) { minus = true b = readByte() } if (b !in '0'.toByte()..'9'.toByte()) { throw NumberFormatException() } while (true) { if (b in '0'.toByte()..'9'.toByte()) { n *= 10 n += b - '0'.toByte() } else if (b == (-1).toByte() || b !in printable) { return if (minus) -n else n } else { throw NumberFormatException() } b = readByte() } } fun int(): Int { val nl = long() if (nl !in Integer.MIN_VALUE..Integer.MAX_VALUE) throw NumberFormatException() return nl.toInt() } fun double(): Double = string().toDouble() fun print(obj: Any) = out.print(obj) fun print(i: Int) = out.print(i) fun print(l: Long) = out.print(l) fun println(obj: Any) = out.println(obj) fun println(i: Int) = out.println(i) fun println(l: Long) = out.println(l) inline fun exec(block: IO.() -> Unit) { block() out.flush() } inline fun println(block: IO.() -> Any) { println(block()) out.flush() } } // endregion