-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlast_stone_weight.rs
68 lines (58 loc) · 1.79 KB
/
last_stone_weight.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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
use std::collections::BinaryHeap;
/// You are given an array of integers `stones` where `stones[i]` is the weight
/// of the `ith` stone.
///
/// We are playing a game with stones. On each turn, we choose the heaviest two
/// stones and smash them together. Supposed the heaviest two stones have
/// weights `x` and `y` with `x <= y`. The result of this smash is:
///
/// * If `x == y`, both stones are destroyed, and
/// * If `x != y`, the stone of weight `x` is destroyed, and the stone of
/// weight `y` has new weight `y - x`.
///
/// At the end of the game, there is at most one stone left.
///
/// Return the weight of the last remaining stone. If there are no stones left,
/// return 0.
struct Solution;
impl Solution {
pub fn last_stone_weight(stones: Vec<i32>) -> i32 {
let mut heap: BinaryHeap<i32> = stones.into();
while heap.len() > 1 {
let y = heap.pop().unwrap();
let x = heap.pop().unwrap();
if x != y {
heap.push(y - x);
}
}
heap.pop().unwrap_or_default()
}
}
#[cfg(test)]
mod tests {
use super::Solution;
#[test]
fn example_1() {
let stones = vec![2, 7, 4, 1, 8, 1];
let result = Solution::last_stone_weight(stones);
assert_eq!(result, 1);
}
#[test]
fn example_2() {
let stones = vec![1];
let result = Solution::last_stone_weight(stones);
assert_eq!(result, 1);
}
#[test]
fn end_with_no_stones() {
let stones = vec![10, 10];
let result = Solution::last_stone_weight(stones);
assert_eq!(result, 0);
}
#[test]
fn end_with_one_stone_with_heavier_weight() {
let stones = vec![10, 7];
let result = Solution::last_stone_weight(stones);
assert_eq!(result, 3);
}
}