結果
| 問題 | No.5 数字のブロック |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-04-12 22:22:51 |
| 言語 | Kotlin (2.3.20) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 484 bytes |
| 記録 | |
| コンパイル時間 | 10,403 ms |
| コンパイル使用メモリ | 469,380 KB |
| 実行使用メモリ | 442,984 KB |
| 最終ジャッジ日時 | 2026-03-17 17:38:48 |
| 合計ジャッジ時間 | 56,651 ms |
|
ジャッジサーバーID (参考情報) |
judge1_1 / judge2_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 12 WA * 10 RE * 12 |
コンパイルメッセージ
Main.kt:16:42: warning: unnecessary non-null assertion (!!) on a non-null receiver of type 'Pair<Int, Int>'.
println(dp.map{ it.maxBy{ it.second }!!.second }.max())
^^
ソースコード
fun main() {
val L = readLine()!!.toInt()
val N = readLine()!!.toInt()
val W = readLine()!!.split(" ").map(String::toInt)
var dp = Array(W.size + 1) { Array(L + 1){ 0 to 0 } }
for(i in 1..W.size) for(k in 0..L) {
if(W[i-1] + dp[i-1][k].first <= k){
dp[i][k] = (dp[i-1][k].first + W[i-1] to dp[i-1][k].second + 1)
}else{
dp[i][k] = dp[i-1][k]
}
}
println(dp.map{ it.maxBy{ it.second }!!.second }.max())
}