結果
問題 | No.1286 Stone Skipping |
ユーザー | da_louis |
提出日時 | 2020-11-13 22:25:39 |
言語 | Kotlin (1.9.23) |
結果 |
WA
|
実行時間 | - |
コード長 | 6,715 bytes |
コンパイル時間 | 21,651 ms |
コンパイル使用メモリ | 475,196 KB |
実行使用メモリ | 58,728 KB |
最終ジャッジ日時 | 2024-07-22 21:18:55 |
合計ジャッジ時間 | 27,246 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 261 ms
58,536 KB |
testcase_01 | AC | 275 ms
58,652 KB |
testcase_02 | AC | 261 ms
58,532 KB |
testcase_03 | AC | 261 ms
58,616 KB |
testcase_04 | AC | 256 ms
58,532 KB |
testcase_05 | WA | - |
testcase_06 | AC | 260 ms
58,640 KB |
testcase_07 | AC | 258 ms
58,460 KB |
testcase_08 | AC | 260 ms
58,612 KB |
testcase_09 | AC | 263 ms
58,620 KB |
testcase_10 | AC | 258 ms
58,536 KB |
testcase_11 | AC | 267 ms
58,636 KB |
testcase_12 | AC | 266 ms
58,544 KB |
testcase_13 | AC | 258 ms
58,616 KB |
testcase_14 | AC | 257 ms
58,596 KB |
testcase_15 | WA | - |
testcase_16 | AC | 252 ms
58,632 KB |
testcase_17 | AC | 255 ms
58,404 KB |
testcase_18 | AC | 256 ms
58,664 KB |
testcase_19 | AC | 270 ms
58,720 KB |
testcase_20 | AC | 264 ms
58,544 KB |
testcase_21 | AC | 257 ms
58,724 KB |
testcase_22 | WA | - |
testcase_23 | WA | - |
testcase_24 | WA | - |
testcase_25 | AC | 333 ms
58,620 KB |
testcase_26 | AC | 329 ms
58,632 KB |
testcase_27 | AC | 257 ms
58,600 KB |
testcase_28 | WA | - |
コンパイルメッセージ
Main.kt:63:48: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. private fun Byte.isNumeric() = this in '0'.toByte()..'9'.toByte() ^ Main.kt:63:62: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. private fun Byte.isNumeric() = this in '0'.toByte()..'9'.toByte() ^ Main.kt:64:68: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. private fun Byte.toNumVal() = if (this.isNumeric()) this - '0'.toByte() else error("$this is not numeric") ^ Main.kt:96:22: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. if (b == '-'.toByte()) { ^ Main.kt:121:22: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. if (b == '-'.toByte()) { ^ Main.kt:127:22: warning: 'toByte(): Byte' is deprecated. Conversion of Char to Number is deprecated. Use Char.code property instead. if (b == '.'.toByte()) { ^
ソースコード
import java.math.BigInteger fun main() = contest274b() @OptIn(ExperimentalStdlibApi::class) fun contest274b() = Messiah_contest274b().exec { val d = readLong() fun calcD(initialVelocity: BigInteger): BigInteger { var D = BigInteger.ZERO var currVelocity = initialVelocity while (currVelocity > BigInteger.ZERO) { D += currVelocity currVelocity /= BigInteger.TWO } return D } // 飛距離 D 以上にする最小値 fun lowerBound(key: Long): BigInteger { var ng = (-1).toBigInteger() var ok = Long.MAX_VALUE.toBigInteger() while ((ok - ng).abs() > BigInteger.ONE) { val mid = (ok + ng) / BigInteger.TWO if (calcD(mid) >= key.toBigInteger()) ok = mid else ng = mid } return ok } val lowerBound = lowerBound(d) fun distances(initialVelocity: BigInteger): Set<BigInteger> { val distances = mutableSetOf<BigInteger>() var D = BigInteger.ZERO var currVelocity = initialVelocity while (currVelocity > BigInteger.ZERO) { D += currVelocity distances += D currVelocity /= BigInteger.TWO } return distances } val distances = distances(lowerBound) val answer = distances.let { if (d.toBigInteger() in it) lowerBound else d.toBigInteger() } println(answer) } // region kokokara template dayo (^o^) @Suppress("MemberVisibilityCanBePrivate", "ClassName", "FunctionName", "PropertyName", "unused") private class Messiah_contest274b(private val separator: String = System.lineSeparator()) { ////////////////////////////////////////////////// // IO ////////////////////////////////////////////////// private val input = System.`in` private val buffer = ByteArray(1024) private var pointer = 0 private var bufferLength = 0 private val sb = StringBuilder() private fun Byte.isPrintable() = this in 33..126 private fun Byte.isNumeric() = this in '0'.toByte()..'9'.toByte() private fun Byte.toNumVal() = if (this.isNumeric()) this - '0'.toByte() else error("$this is not numeric") private val enableDebugMode = "ENABLE_DEBUG_MODE_FOR_COMPETITIVE_PROGRAMING" in System.getenv() private fun hasNextByte(): Boolean { return if (pointer < bufferLength) true else { pointer = 0 bufferLength = input.read(buffer) bufferLength > 0 } } private fun readByte(): Byte = if (hasNextByte()) buffer[pointer++] else -1 private fun skipUnprintable() = run { while (hasNextByte() && !buffer[pointer].isPrintable()) pointer++ } private fun hasNext(): Boolean = run { skipUnprintable() }.run { hasNextByte() } private fun hasNextOrError() = if (!hasNext()) error("has no next element.") else Unit fun readString(): String { hasNextOrError() val sb = StringBuilder() var b = readByte() while (b.isPrintable()) { sb.appendCodePoint(b.toInt()) b = readByte() } return sb.toString() } fun readLong(): Long { hasNextOrError() var n = 0L var negative = false var b = readByte() if (b == '-'.toByte()) { negative = true b = readByte() } if (!b.isNumeric()) error("$b is not numeric.") while (true) { when { b.isNumeric() -> n = n * 10 + b.toNumVal() b.toInt() == -1 || !b.isPrintable() -> return if (negative) -n else n else -> error("failed to parse. [n=$n, b=$b]") } b = readByte() } } fun readInt() = readLong() .let { if (it in Int.MIN_VALUE..Int.MAX_VALUE) it.toInt() else error("$it is not in range of Int.") } fun readIntAsIndex() = readInt().dec() fun readDouble(): Double { var n = 0.0 var div = 1.0 var negative = false var b = readByte() if (b == '-'.toByte()) { negative = true b = readByte() } do n = n * 10 + b.toNumVal() while (run { b = readByte() }.run { b.isNumeric() }) if (b == '.'.toByte()) { while (run { b = readByte() }.run { b.isNumeric() }) n += b.toNumVal() / (run { div *= 10 }.run { div }) } return if (negative) -n else n } fun readString(size: Int): Array<String> = Array(size) { readString() } fun readChars2D(height: Int): Array<CharArray> = Array(height) { readString().toCharArray() } fun readLong(size: Int): LongArray = LongArray(size) { readLong() } fun readLong2D(height: Int, width: Int): Array<LongArray> = Array(height) { LongArray(width) { readLong() } } fun readInt(size: Int): IntArray = IntArray(size) { readInt() } fun readInt2D(height: Int, width: Int): Array<IntArray> = Array(height) { IntArray(width) { readInt() } } fun readIntAsIndex(size: Int): IntArray = IntArray(size) { readIntAsIndex() } fun readIntAsIndex2D(height: Int, width: Int): Array<IntArray> = Array(height) { IntArray(width) { readIntAsIndex() } } fun readDouble(size: Int): DoubleArray = DoubleArray(size) { readDouble() } fun println(): Unit = run { sb.append(separator) } fun print(any: Any): Unit = run { sb.append(any.toString()) } fun println(any: Any): Unit = run { sb.append(any.toString() + separator) } fun flush() = run { kotlin.io.println(sb); sb.clear() } fun debug(any: Any): Unit = run { if (enableDebugMode) System.err.println(any) } fun debug(action: () -> Unit): Unit = run { if (enableDebugMode) action() } fun exec(action: Messiah_contest274b.() -> Unit) { var t: Throwable? = null Thread(null, { action() }, "solve", 128 * 1024 * 1024) .apply { setUncaughtExceptionHandler { _, t1 -> t = t1 } } .apply { start() }.join() t?.let { throw it } kotlin.io.print(sb) } fun readLine(): Nothing = error("readLine is disabled.") ////////////////////////////////////////////////// // Misc ////////////////////////////////////////////////// /** * `[index] in [this]` is sugar syntax of `index in 0 until [this]`. */ operator fun Int.contains(index: Int) = index in this.indices() /** * `[this].indices()` is sugar syntax of `0 until [this]`. */ fun Int.indices() = 0 until this fun YesNo(b: Boolean): String = if (b) Yes else No val Yes = "Yes" val No = "No" fun YES_NO(b: Boolean): String = if (b) YES else NO val YES = "YES" val NO = "NO" } // endregion kokomade template dayo (^o^)