結果
問題 |
No.45 回転寿司
|
ユーザー |
![]() |
提出日時 | 2018-09-04 01:33:30 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,032 bytes |
コンパイル時間 | 20,218 ms |
コンパイル使用メモリ | 376,820 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-12-27 19:22:03 |
合計ジャッジ時間 | 17,436 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 30 |
ソースコード
use std::io::*; use std::str::FromStr; use std::cmp::max; #[allow(dead_code)] fn get_line() -> String { let stdin = stdin(); let mut line = String::new(); stdin.lock().read_line(&mut line).expect("io error."); line.trim().to_string() } #[allow(dead_code)] fn cast<T: FromStr>(s: &str) -> T { s.parse().ok().expect("parse error.") } #[allow(dead_code)] fn get_vec<T: FromStr>() -> Vec<T> { (&get_line()).split(' ').map(cast::<T>).collect() } /* ---------- ここまでテンプレ ---------- */ fn main() { let n: usize = cast(&get_line()); let v: Vec<u64> = get_vec(); let mut dp = vec![vec![0u64; n]; 2]; // dp[0][i] = v[i]番目を 食べなかった ときの最大値 // dp[1][i] = 食べた dp[1][0] = v[0]; for i in 1..n { dp[0][i] = max(dp[0][i - 1], dp[1][i - 1]); dp[1][i] = dp[0][i - 1] + v[i]; } /* println!("{:?}", dp[0]); println!("{:?}", dp[1]); */ println!("{}", max(dp[0][n - 1], dp[1][n - 1])); }