結果

問題 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()
                             ^

ソースコード

diff #

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
0