// No.35 タイパー高橋 // https://yukicoder.me/problems/no/35 package no01.yukicoder.no35 /** インプットデータ */ data class InputData( /** 1ゲームの区間の数 */ val count: Int, /** 制限時間と入力すべき文字列 */ val timeAndStr: List ) /** 制限時間と入力すべき文字列 */ data class TimeAndString( /** 制限時間 */ val time: Int, /** 入力すべき文字列 */ val str: String ) /** * エントリポイント */ fun main(args: Array) { val input = getStandardInput() println(typing(input)) } /** * タイプできる文字数、タイプできない文字数を返します。 */ fun typing(input: List): 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): InputData { val count = input[0].toInt() val timeAndStr = mutableListOf() 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 { val lines = mutableListOf() var line: String? line = readLine() while (line != null) { lines.add(line) line = readLine() } return lines }