2022-07-12 09:18:05 -04:00
|
|
|
// hashmaps2.rs
|
2023-03-26 09:21:21 -04: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.
|
2023-03-20 07:04:47 -04:00
|
|
|
// You are not allowed to insert any more of these fruits!
|
2020-10-26 08:08:48 -04:00
|
|
|
//
|
|
|
|
// Make me pass the tests!
|
|
|
|
//
|
2022-07-14 06:58:28 -04:00
|
|
|
// Execute `rustlings hint hashmaps2` or use the `hint` watch subcommand for a hint.
|
2020-10-26 08:08:48 -04:00
|
|
|
|
|
|
|
// I AM NOT DONE
|
|
|
|
|
|
|
|
use std::collections::HashMap;
|
|
|
|
|
|
|
|
#[derive(Hash, PartialEq, Eq)]
|
|
|
|
enum Fruit {
|
|
|
|
Apple,
|
|
|
|
Banana,
|
|
|
|
Mango,
|
2021-04-09 17:08:02 -04:00
|
|
|
Lychee,
|
2020-10-26 08:08:48 -04:00
|
|
|
Pineapple,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn fruit_basket(basket: &mut HashMap<Fruit, u32>) {
|
|
|
|
let fruit_kinds = vec![
|
|
|
|
Fruit::Apple,
|
|
|
|
Fruit::Banana,
|
|
|
|
Fruit::Mango,
|
2021-04-09 17:08:02 -04:00
|
|
|
Fruit::Lychee,
|
2020-10-26 08:08:48 -04:00
|
|
|
Fruit::Pineapple,
|
|
|
|
];
|
|
|
|
|
|
|
|
for fruit in fruit_kinds {
|
2023-03-26 09:21:21 -04:00
|
|
|
// TODO: Insert new fruits if they are not already present in the basket.
|
2023-03-20 07:04:47 -04:00
|
|
|
// Note that you are not allowed to put any type of fruit that's already
|
2020-10-26 08:08:48 -04:00
|
|
|
// present!
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
|
|
|
use super::*;
|
|
|
|
|
2023-03-20 07:04:47 -04:00
|
|
|
// Don't modify this function!
|
2020-10-26 08:08:48 -04: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 17:08:02 -04:00
|
|
|
basket.insert(Fruit::Lychee, 5);
|
2020-10-26 08:08:48 -04: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 17:08:02 -04:00
|
|
|
assert_eq!(*basket.get(&Fruit::Lychee).unwrap(), 5);
|
2020-10-26 08:08:48 -04: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 05:15:49 -04:00
|
|
|
assert!(count_fruit_kinds >= 5);
|
2020-10-26 08:08:48 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn greater_than_eleven_fruits() {
|
|
|
|
let mut basket = get_fruit_basket();
|
|
|
|
fruit_basket(&mut basket);
|
2021-03-18 13:45:01 -04:00
|
|
|
let count = basket.values().sum::<u32>();
|
2020-10-26 08:08:48 -04:00
|
|
|
assert!(count > 11);
|
|
|
|
}
|
2023-06-08 09:49:07 -04: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 08:08:48 -04:00
|
|
|
}
|