-
Notifications
You must be signed in to change notification settings - Fork 111
/
Copy pathmaximum-subarray-min-product.rs
41 lines (39 loc) · 1.47 KB
/
maximum-subarray-min-product.rs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
impl Solution {
pub fn max_sum_min_product(a: Vec<i32>) -> i32 {
let mut st = vec![];
let mut l: Vec<usize> = vec![0; a.len()];
let mut r: Vec<usize> = vec![a.len(); a.len()];
for (i, &x) in a.iter().enumerate() {
while let Some(&j) = st.last() {
if a[j] < x { break; }
r[j] = i;
st.pop();
}
if let Some(&j) = st.last() { l[i] = j+1; }
st.push(i);
}
let sum: Box<[i64]> = std::iter::once(0).chain(a.iter().scan(0, |s,&y| { *s += y as i64; Some(*s) })).collect();
let mut ans = 0;
for i in 0..a.len() {
ans = ans.max((sum[r[i]]-sum[l[i]]) * a[i] as i64);
}
(ans % 1000000007) as i32
}
}
///
impl Solution {
pub fn max_sum_min_product(a: Vec<i32>) -> i32 {
use std::{iter,usize::MAX};
let sum: Box<[i64]> = iter::once(0).chain(a.iter().scan(0, |s,&y| { *s += y as i64; Some(*s) })).collect();
let mut b: Vec<(usize,i32)> = a.into_iter().enumerate().collect();
b.sort_unstable_by_key(|v| std::cmp::Reverse(v.1));
let mut c: Vec<usize> = vec![MAX; b.len()];
(b.iter().fold(0, |acc,&(i,v)| {
let l = if i>0 && c[i-1]!=MAX { c[i-1] } else { i };
let r = if i+1<b.len() && c[i+1]!=MAX { c[i+1] } else { i };
c[l] = r;
c[r] = l;
acc.max((sum[r+1]-sum[l]) * v as i64)
}) % 1000000007) as i32
}
}