結果
問題 | No.27 板の準備 |
ユーザー | phspls |
提出日時 | 2022-09-04 21:53:04 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 6 ms / 5,000 ms |
コード長 | 1,351 bytes |
コンパイル時間 | 12,600 ms |
コンパイル使用メモリ | 402,208 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-19 05:19:29 |
合計ジャッジ時間 | 13,775 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 18 |
ソースコード
const INF: usize = 1usize << 60; fn main() { let mut v0123 = String::new(); std::io::stdin().read_line(&mut v0123).ok(); let v: Vec<usize> = v0123.trim().split_whitespace().map(|s| s.parse().unwrap()).collect(); let mut result = INF; for i in 1..=30 { for j in i+1..=30 { for k in j+1..=30 { let mut cnt = 0usize; let mut flg = true; let selector = [i,j,k]; for l in 0..4 { let mut dp = vec![vec![INF; 1+v[l]]; 4]; dp[0][0] = 0; for ii in 0..3 { for jj in 0..=v[l] { if dp[ii][jj] == INF { continue; } for kk in 0..=(v[l]-jj)/selector[ii] { dp[ii+1][jj+kk*selector[ii]] = dp[ii+1][jj+kk*selector[ii]].min(dp[ii][jj]+kk); } } } if dp[3][v[l]] == INF { flg = false; break; } else { cnt += dp[3][v[l]]; } } if flg { result = result.min(cnt); } } } } println!("{}", result); }