結果
問題 | No.35 タイパー高橋 |
ユーザー | yo-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>) { ^
ソースコード
// 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 }