結果
問題 |
No.5 数字のブロック
|
ユーザー |
|
提出日時 | 2019-01-03 12:02:38 |
言語 | Kotlin (2.1.0) |
結果 |
AC
|
実行時間 | 412 ms / 5,000 ms |
コード長 | 1,796 bytes |
コンパイル時間 | 11,282 ms |
コンパイル使用メモリ | 443,068 KB |
実行使用メモリ | 56,604 KB |
最終ジャッジ日時 | 2024-11-20 17:19:41 |
合計ジャッジ時間 | 24,377 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 34 |
コンパイルメッセージ
Main.kt:27:10: warning: parameter 'args' is never used fun main(args: Array<String>) { ^
ソースコード
// No.5 数字のブロック // https://yukicoder.me/problems/no/5 package no01.yukicoder.no5 /** * インプットデータ */ data class InputData( /** * 箱の幅 */ val boxWidth: Int, /** * ブロックの数 */ val blockNum: Int, /** * 各ブロックの幅 */ val blockWidth: List<Int> ) /** * エントリポイント */ fun main(args: Array<String>) { val input = getStandardInput() println(block(input)) } /** * 箱に入るブロックの数を計算して返します。 */ fun block(input: List<String>): Int { val data = createInputData(input) // sorted で List をソート。 // sortedDescending()で降順にソート val sortedBlock = data.blockWidth.sorted() var inBlockNum = 0 var inBlockWidth = 0 // 小さいブロックから数えて、箱の幅を超えたら終了 for (v in sortedBlock) { if (v + inBlockWidth <= data.boxWidth) { inBlockNum++ inBlockWidth += v } else { break } } return inBlockNum } /** * 標準入力から取得した文字列をInputDataに変換して返します。 */ fun createInputData(input: List<String>): InputData { val blockWidth = input[2] .split(" ") .map { it.toInt() } return InputData(input[0].toInt(), input[1].toInt(), blockWidth) } /** * 標準入力から文字列を全て取得します。 */ fun getStandardInput(): List<String> { val lines = mutableListOf<String>() var line: String? // readLine で標準入力から文字列を取得 line = readLine() // 入力がなくなるまで取得する while (line != null) { lines.add(line) line = readLine() } return lines }