結果
| 問題 |
No.1858 Gorgeous Knapsack
|
| ユーザー |
ID 21712
|
| 提出日時 | 2025-06-09 23:12:12 |
| 言語 | Go (1.23.4) |
| 結果 |
AC
|
| 実行時間 | 312 ms / 2,000 ms |
| コード長 | 743 bytes |
| コンパイル時間 | 11,401 ms |
| コンパイル使用メモリ | 234,400 KB |
| 実行使用メモリ | 8,232 KB |
| 最終ジャッジ日時 | 2025-06-09 23:12:29 |
| 合計ジャッジ時間 | 15,251 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 37 |
ソースコード
package main
import . "fmt"
import . "sort"
func main() {
var n, m int
Scan(&n,&m)
type X struct { v,w int }
xs := make([]*X, 0, n)
for i := 0; i < n; i++ {
x := new(X)
Scan(&x.v, &x.w)
if x.w <= m {
xs = append(xs, x)
}
}
Slice(xs, func(i, j int) bool {
return xs[i].v > xs[j].v
})
ans := 0
type Y struct { sum int }
kn := make([]*Y, m+1)
for _, x := range xs {
for i := m; i >= 0; i-- {
if kn[i] == nil || i+x.w > m {
continue
}
y := &Y{ kn[i].sum+x.v }
if z := kn[i+x.w]; z == nil || y.sum > z.sum {
ans = max(ans, x.v * y.sum)
kn[i+x.w] = y
}
}
yy := &Y{ x.v }
if z := kn[x.w]; z == nil || yy.sum > z.sum {
ans = max(ans, x.v * yy.sum)
kn[x.w] = yy
}
}
Println(ans)
}
ID 21712