結果
| 問題 |
No.35 タイパー高橋
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2019-01-03 17:58:00 |
| 言語 | Kotlin (2.1.0) |
| 結果 |
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 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 4 |
コンパイルメッセージ
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
}