結果
| 問題 |
No.45 回転寿司
|
| ユーザー |
_yoshih_
|
| 提出日時 | 2018-10-03 11:56:53 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 5,000 ms |
| コード長 | 986 bytes |
| コンパイル時間 | 21,220 ms |
| コンパイル使用メモリ | 377,456 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-12-27 19:34:48 |
| 合計ジャッジ時間 | 13,917 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 30 |
ソースコード
use std::io::*;
use std::str::*;
use std::cmp::max;
#[allow(dead_code)]
fn get_line(sl: &mut StdinLock) -> String {
let mut line = String::new();
sl.read_line(&mut line).expect("cannot read line");
line.trim().to_string()
}
#[allow(dead_code)]
fn cast<T: FromStr>(s: &str) -> T {
s.parse().ok().expect("cannot cast from str")
}
#[allow(dead_code)]
fn get_vec<T: FromStr>(sl: &mut StdinLock, n: usize) -> Vec<T> {
(&get_line(sl)).split(' ').map(cast::<T>).take(n).collect()
}
fn run(sl: &mut StdinLock) {
let n = cast::<usize>(&get_line(sl));
let mut vs = [0; 1000 + 1];
let ss = get_line(sl);
(&ss).split(' ').take(n).enumerate().for_each(|(i, s)| vs[i] = cast::<i32>(s));
let mut dp = [0; 1000 + 1];
dp[0] = 0;
dp[1] = vs[0];
(2..=n).for_each(|i| {
dp[i] = max(dp[i - 2] + vs[i - 1], dp[i - 1]);
});
println!("{}", dp[n]);
}
fn main() {
let s = stdin();
let mut sl = s.lock();
run(&mut sl);
}
_yoshih_