結果

問題 No.35 タイパー高橋
ユーザー yo-kondoyo-kondo
提出日時 2019-01-03 17:58:00
言語 Kotlin
(1.9.23)
結果
AC  
実行時間 442 ms / 5,000 ms
コード長 1,978 bytes
コンパイル時間 12,917 ms
コンパイル使用メモリ 438,068 KB
実行使用メモリ 56,476 KB
最終ジャッジ日時 2024-11-20 17:21:46
合計ジャッジ時間 15,478 ms
ジャッジサーバーID
(参考情報)
judge2 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 441 ms
56,220 KB
testcase_01 AC 441 ms
56,476 KB
testcase_02 AC 441 ms
56,168 KB
testcase_03 AC 442 ms
55,964 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
Main.kt:25:10: warning: parameter 'args' is never used
fun main(args: Array<String>) {
         ^

ソースコード

diff #

// No.35 タイパー高橋
// https://yukicoder.me/problems/no/35

package no01.yukicoder.no35

/** インプットデータ */
data class InputData(
    /** 1ゲームの区間の数 */
    val count: Int,
    /** 制限時間と入力すべき文字列 */
    val timeAndStr: List<TimeAndString>
)

/** 制限時間と入力すべき文字列 */
data class TimeAndString(
    /** 制限時間 */
    val time: Int,
    /** 入力すべき文字列 */
    val str: String
)

/**
 * エントリポイント
 */
fun main(args: Array<String>) {
    val input = getStandardInput()
    println(typing(input))
}

/**
 * タイプできる文字数、タイプできない文字数を返します。
 */
fun typing(input: List<String>): String {
    val data = createInputData(input)

    var ok = 0
    var ng = 0

    for (v in data.timeAndStr) {
        // 1秒間に打てる文字数(toInt()で小数点切り捨て)
        val typeCh = (v.time / 1000.0 * 12).toInt()

        if (v.str.length <= typeCh) {
            // 全部入力
            ok += v.str.length
        } else {
            // 一部入力
            ok += typeCh
            ng += v.str.length - typeCh
        }
    }
    return "$ok $ng"
}

/**
 * 標準入力から取得した文字列をInputDataに変換して返します。
 */
fun createInputData(input: List<String>): InputData {
    val count = input[0].toInt()
    val timeAndStr = mutableListOf<TimeAndString>()

    for ((i, v) in input.withIndex()) {
        if (i == 0) continue

        val sp = v.split(" ")
        val tas = TimeAndString(sp[0].toInt(), sp[1])
        timeAndStr.add(tas)
    }

    return InputData(count, timeAndStr)
}

/**
 * 標準入力から文字列を全て取得します。
 */
fun getStandardInput(): List<String> {
    val lines = mutableListOf<String>()
    var line: String?
    line = readLine()
    while (line != null) {
        lines.add(line)
        line = readLine()
    }
    return lines
}
0