2022-07-12 16:18:05 +03:00
|
|
|
// hashmaps2.rs
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
|
|
|
// We're collecting different fruits to bake a delicious fruit cake. For this,
|
|
|
|
// we have a basket, which we'll represent in the form of a hash map. The key
|
|
|
|
// represents the name of each fruit we collect and the value represents how
|
|
|
|
// many of that particular fruit we have collected. Three types of fruits -
|
|
|
|
// Apple (4), Mango (2) and Lychee (5) are already in the basket hash map. You
|
|
|
|
// must add fruit to the basket so that there is at least one of each kind and
|
|
|
|
// more than 11 in total - we have a lot of mouths to feed. You are not allowed
|
|
|
|
// to insert any more of these fruits!
|
2020-10-26 15:08:48 +03:00
|
|
|
//
|
|
|
|
// Make me pass the tests!
|
|
|
|
//
|
2023-05-29 20:39:08 +03:00
|
|
|
// Execute `rustlings hint hashmaps2` or use the `hint` watch subcommand for a
|
|
|
|
// hint.
|
2020-10-26 15:08:48 +03:00
|
|
|
|
|
|
|
use std::collections::HashMap;
|
|
|
|
|
|
|
|
#[derive(Hash, PartialEq, Eq)]
|
|
|
|
enum Fruit {
|
|
|
|
Apple,
|
|
|
|
Banana,
|
|
|
|
Mango,
|
2021-04-10 00:08:02 +03:00
|
|
|
Lychee,
|
2020-10-26 15:08:48 +03:00
|
|
|
Pineapple,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fruit_basket(basket: &mut HashMap<Fruit, u32>) {
|
|
|
|
let fruit_kinds = vec![
|
|
|
|
Fruit::Apple,
|
|
|
|
Fruit::Banana,
|
|
|
|
Fruit::Mango,
|
2021-04-10 00:08:02 +03:00
|
|
|
Fruit::Lychee,
|
2020-10-26 15:08:48 +03:00
|
|
|
Fruit::Pineapple,
|
|
|
|
];
|
|
|
|
|
|
|
|
for fruit in fruit_kinds {
|
2023-05-29 20:39:08 +03:00
|
|
|
// TODO: Insert new fruits if they are not already present in the
|
|
|
|
// basket. Note that you are not allowed to put any type of fruit that's
|
|
|
|
// already present!
|
2024-02-01 19:08:03 +03:00
|
|
|
basket.entry(fruit).or_insert(1);
|
2020-10-26 15:08:48 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
|
2023-03-20 14:04:47 +03:00
|
|
|
// Don't modify this function!
|
2020-10-26 15:08:48 +03:00
|
|
|
fn get_fruit_basket() -> HashMap<Fruit, u32> {
|
|
|
|
let mut basket = HashMap::<Fruit, u32>::new();
|
|
|
|
basket.insert(Fruit::Apple, 4);
|
|
|
|
basket.insert(Fruit::Mango, 2);
|
2021-04-10 00:08:02 +03:00
|
|
|
basket.insert(Fruit::Lychee, 5);
|
2020-10-26 15:08:48 +03:00
|
|
|
|
|
|
|
basket
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_given_fruits_are_not_modified() {
|
|
|
|
let mut basket = get_fruit_basket();
|
|
|
|
fruit_basket(&mut basket);
|
|
|
|
assert_eq!(*basket.get(&Fruit::Apple).unwrap(), 4);
|
|
|
|
assert_eq!(*basket.get(&Fruit::Mango).unwrap(), 2);
|
2021-04-10 00:08:02 +03:00
|
|
|
assert_eq!(*basket.get(&Fruit::Lychee).unwrap(), 5);
|
2020-10-26 15:08:48 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn at_least_five_types_of_fruits() {
|
|
|
|
let mut basket = get_fruit_basket();
|
|
|
|
fruit_basket(&mut basket);
|
|
|
|
let count_fruit_kinds = basket.len();
|
2021-04-20 12:15:49 +03:00
|
|
|
assert!(count_fruit_kinds >= 5);
|
2020-10-26 15:08:48 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn greater_than_eleven_fruits() {
|
|
|
|
let mut basket = get_fruit_basket();
|
|
|
|
fruit_basket(&mut basket);
|
2021-03-18 20:45:01 +03:00
|
|
|
let count = basket.values().sum::<u32>();
|
2020-10-26 15:08:48 +03:00
|
|
|
assert!(count > 11);
|
|
|
|
}
|
2023-06-08 16:49:07 +03:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn all_fruit_types_in_basket() {
|
|
|
|
let mut basket = get_fruit_basket();
|
|
|
|
fruit_basket(&mut basket);
|
|
|
|
for amount in basket.values() {
|
|
|
|
assert_ne!(amount, &0);
|
|
|
|
}
|
|
|
|
}
|
2020-10-26 15:08:48 +03:00
|
|
|
}
|