結果
| 問題 |
No.561 東京と京都
|
| コンテスト | |
| ユーザー |
tubo28
|
| 提出日時 | 2017-08-25 22:37:52 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 2,000 ms |
| コード長 | 1,339 bytes |
| コンパイル時間 | 12,558 ms |
| コンパイル使用メモリ | 378,872 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-10-15 16:29:59 |
| 合計ジャッジ時間 | 13,487 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 17 |
ソースコード
use std::cmp::*;
use std::io::*;
use std::str::*;
use std::fmt::*;
fn readw<T: FromStr, R: Read>(s: &mut R) -> Option<T> {
let s = s.bytes().map(|c| c.unwrap() as char)
.skip_while(|c| c.is_whitespace())
.take_while(|c| !c.is_whitespace())
.collect::<String>();
if s.is_empty() {
None
} else {
s.parse::<T>().ok()
}
}
fn read<T: FromStr, R: Read>(s: &mut R) -> T {
readw(s).unwrap()
}
#[allow(dead_code)]
fn p<A: Display>(a: &A) {
println!("{}", a);
}
#[allow(dead_code)]
fn p2<A: Display, B: Display>(a: &A, b: &B) {
println!("{} {}", a, b);
}
#[allow(dead_code)]
fn p3<A: Display, B: Display, C: Display>(a: &A, b: &B, c: &C) {
println!("{} {} {}", a, b, c);
}
fn main(){
let s = stdin();
let mut s = BufReader::new(s.lock());
let s = &mut s;
while let Some(n) = readw(s) {
let d: i64 = read(s);
let mut t = vec![0; n];
let mut k = vec![0; n];
for i in 0..n {
t[i] = read(s);
k[i] = read(s);
}
let mut a = 0;
let mut b = -100000000_000000000;
for i in 0..n {
let na = max(a + t[i], b - d + t[i]);
let nb = max(b + k[i], a - d + k[i]);
a = na;
b = nb;
}
println!("{}", max(a, b));
}
}
tubo28