From 185fa7406c38d650ae2d2c02224f2351f8416724 Mon Sep 17 00:00:00 2001 From: koba-e964 <3303362+koba-e964@users.noreply.github.com> Date: Sun, 5 May 2024 22:22:06 +0900 Subject: [PATCH] Add atcoder/abc341/g.rs --- atcoder/abc341/g.rs | 64 +++++++++++++++++++++++++++++++++++++++ atcoder/abc341/remain.txt | 1 - 2 files changed, 64 insertions(+), 1 deletion(-) create mode 100644 atcoder/abc341/g.rs delete mode 100644 atcoder/abc341/remain.txt diff --git a/atcoder/abc341/g.rs b/atcoder/abc341/g.rs new file mode 100644 index 00000000..21ee1817 --- /dev/null +++ b/atcoder/abc341/g.rs @@ -0,0 +1,64 @@ +use std::io::{Write, BufWriter}; +// https://qiita.com/tanakh/items/0ba42c7ca36cd29d0ac8 +macro_rules! input { + ($($r:tt)*) => { + let stdin = std::io::stdin(); + let mut bytes = std::io::Read::bytes(std::io::BufReader::new(stdin.lock())); + let mut next = move || -> String{ + bytes.by_ref().map(|r|r.unwrap() as char) + .skip_while(|c|c.is_whitespace()) + .take_while(|c|!c.is_whitespace()) + .collect() + }; + input_inner!{next, $($r)*} + }; +} + +macro_rules! input_inner { + ($next:expr) => {}; + ($next:expr,) => {}; + ($next:expr, $var:ident : $t:tt $($r:tt)*) => { + let $var = read_value!($next, $t); + input_inner!{$next $($r)*} + }; +} + +macro_rules! read_value { + ($next:expr, [ $t:tt ; $len:expr ]) => { + (0..$len).map(|_| read_value!($next, $t)).collect::>() + }; + ($next:expr, $t:ty) => ($next().parse::<$t>().expect("Parse error")); +} + +fn main() { + let out = std::io::stdout(); + let mut out = BufWriter::new(out.lock()); + macro_rules! puts {($($format:tt)*) => (let _ = write!(out,$($format)*););} + input! { + n: usize, + a: [i64; n], + } + let mut acc = vec![0; n + 1]; + for i in 0..n { + acc[i + 1] = acc[i] + a[i]; + } + let mut st = vec![(n as i64, acc[n])]; + let mut dp = vec![0.0; n]; + for i in (0..n).rev() { + let (x, y) = (i as i64, acc[i]); + while st.len() >= 2 { + let (x2, y2) = st[st.len() - 1]; + let (x1, y1) = st[st.len() - 2]; + if (y2 - y1) * (x1 - x) > (y1 - y) * (x2 - x1) { + break; + } + st.pop(); + } + let (x2, y2) = st[st.len() - 1]; + dp[i] = (y2 - y) as f64 / (x2 - x) as f64; + st.push((x, y)); + } + for i in 0..n { + puts!("{}\n", dp[i]); + } +} diff --git a/atcoder/abc341/remain.txt b/atcoder/abc341/remain.txt deleted file mode 100644 index 01058d84..00000000 --- a/atcoder/abc341/remain.txt +++ /dev/null @@ -1 +0,0 @@ -g