結果
| 問題 | 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
}