2022-07-12 15:18:05 +02:00
|
|
|
// hashmaps2.rs
|
2023-05-29 19:39:08 +02: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 14:08:48 +02:00
|
|
|
//
|
|
|
|
// Make me pass the tests!
|
|
|
|
//
|
2023-05-29 19:39:08 +02:00
|
|
|
// Execute `rustlings hint hashmaps2` or use the `hint` watch subcommand for a
|
|
|
|
// hint.
|
2020-10-26 14:08:48 +02:00
|
|
|
|
|
|
|
// I AM NOT DONE
|
|
|
|
|
|
|
|
use std::collections::HashMap;
|
|
|
|
|
|
|
|
#[derive(Hash, PartialEq, Eq)]
|
|
|
|
enum Fruit {
|
|
|
|
Apple,
|
|
|
|
Banana,
|
|
|
|
Mango,
|
2021-04-09 23:08:02 +02:00
|
|
|
Lychee,
|
2020-10-26 14:08:48 +02:00
|
|
|
Pineapple,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fruit_basket(basket: &mut HashMap<Fruit, u32>) {
|
|
|
|
let fruit_kinds = vec![
|
|
|
|
Fruit::Apple,
|
|
|
|
Fruit::Banana,
|
|
|
|
Fruit::Mango,
|
2021-04-09 23:08:02 +02:00
|
|
|
Fruit::Lychee,
|
2020-10-26 14:08:48 +02:00
|
|
|
Fruit::Pineapple,
|
|
|
|
];
|
|
|
|
|
|
|
|
for fruit in fruit_kinds {
|
2023-05-29 19:39:08 +02: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!
|
2020-10-26 14:08:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
|
2023-03-20 13:04:47 +02:00
|
|
|
// Don't modify this function!
|
2020-10-26 14:08:48 +02: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-09 23:08:02 +02:00
|
|
|
basket.insert(Fruit::Lychee, 5);
|
2020-10-26 14:08:48 +02: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-09 23:08:02 +02:00
|
|
|
assert_eq!(*basket.get(&Fruit::Lychee).unwrap(), 5);
|
2020-10-26 14:08:48 +02: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 11:15:49 +02:00
|
|
|
assert!(count_fruit_kinds >= 5);
|
2020-10-26 14:08:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn greater_than_eleven_fruits() {
|
|
|
|
let mut basket = get_fruit_basket();
|
|
|
|
fruit_basket(&mut basket);
|
2021-03-18 19:45:01 +02:00
|
|
|
let count = basket.values().sum::<u32>();
|
2020-10-26 14:08:48 +02:00
|
|
|
assert!(count > 11);
|
|
|
|
}
|
2023-06-08 15:49:07 +02: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 14:08:48 +02:00
|
|
|
}
|