20240201 Finished

This commit is contained in:
jackfiled 2024-02-01 11:13:56 +08:00
parent 06d2f3a149
commit d3c127480b
2 changed files with 67 additions and 1 deletions

View File

@ -0,0 +1,65 @@
pub struct Solution {}
use std::collections::BinaryHeap;
use std::cmp::Reverse;
impl Solution {
pub fn nums_game(nums: Vec<i32>) -> Vec<i32> {
let mut result = Vec::with_capacity(nums.len());
let m = 1000000007i64;
let (mut lower, mut upper) =
(BinaryHeap::new(), BinaryHeap::new());
let (mut lower_sum, mut upper_sum) = (0i64, 0i64);
for (index, value) in nums.iter().enumerate() {
let value = *value - index as i32;
let peek = lower.peek();
if peek.is_none() || *peek.unwrap() >= value {
lower_sum += value as i64;
lower.push(value);
if lower.len() > upper.len() + 1 {
let peek = lower.pop().unwrap();
upper.push(Reverse(peek));
upper_sum += peek as i64;
lower_sum -= peek as i64;
}
} else {
upper_sum += value as i64;
upper.push(Reverse(value));
if lower.len() < upper.len() {
let peek = upper.pop().unwrap().0;
lower.push(peek);
lower_sum += peek as i64;
upper_sum -= peek as i64;
}
}
if (index + 1) % 2 == 0 {
result.push(((upper_sum - lower_sum) % m) as i32 );
} else {
result.push(((upper_sum - lower_sum + *lower.peek().unwrap() as i64)
% m) as i32);
}
}
result
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_lcp24() {
assert_eq!(Solution::nums_game(vec![3,4,5,1,6,7]), vec![0,0,0,5,6,7]);
assert_eq!(Solution::nums_game(vec![1,2,3,4,5]), vec![0,0,0,0,0]);
assert_eq!(Solution::nums_game(vec![471, 626, 848]), vec![0, 154,375]);
}
}

View File

@ -34,3 +34,4 @@ mod p365_water_and_jug_problem;
mod p514_freedom_trail; mod p514_freedom_trail;
mod p2808_minimum_seconds_to_equalize_a_circular_array; mod p2808_minimum_seconds_to_equalize_a_circular_array;
mod p2670_find_the_distinct_difference_array; mod p2670_find_the_distinct_difference_array;
mod lcp24_nums_game;