finish hashmap and quiz2

This commit is contained in:
horaoen 2023-12-28 16:54:22 +08:00
parent 4bd2ca16c4
commit 0cbbe09cc6
4 changed files with 35 additions and 24 deletions

View File

@ -11,18 +11,18 @@
// Execute `rustlings hint hashmaps1` or use the `hint` watch subcommand for a // Execute `rustlings hint hashmaps1` or use the `hint` watch subcommand for a
// hint. // hint.
// I AM NOT DONE
use std::collections::HashMap; use std::collections::HashMap;
fn fruit_basket() -> HashMap<String, u32> { fn fruit_basket() -> HashMap<String, u32> {
let mut basket = // TODO: declare your hash map here. let mut basket: HashMap<String, u32> = HashMap::new();
// Two bananas are already given for you :) // Two bananas are already given for you :)
basket.insert(String::from("banana"), 2); basket.insert(String::from("banana"), 2);
// TODO: Put more fruits in your basket here. // TODO: Put more fruits in your basket here.
basket.insert(String::from("apple"), 2);
basket.insert(String::from("orange"), 2);
basket basket
} }

View File

@ -14,8 +14,6 @@
// Execute `rustlings hint hashmaps2` or use the `hint` watch subcommand for a // Execute `rustlings hint hashmaps2` or use the `hint` watch subcommand for a
// hint. // hint.
// I AM NOT DONE
use std::collections::HashMap; use std::collections::HashMap;
#[derive(Hash, PartialEq, Eq)] #[derive(Hash, PartialEq, Eq)]
@ -37,9 +35,9 @@ fn fruit_basket(basket: &mut HashMap<Fruit, u32>) {
]; ];
for fruit in fruit_kinds { for fruit in fruit_kinds {
// TODO: Insert new fruits if they are not already present in the if !basket.contains_key(&fruit) {
// basket. Note that you are not allowed to put any type of fruit that's basket.insert(fruit, 1);
// already present! }
} }
} }
@ -81,7 +79,7 @@ mod tests {
let count = basket.values().sum::<u32>(); let count = basket.values().sum::<u32>();
assert!(count > 11); assert!(count > 11);
} }
#[test] #[test]
fn all_fruit_types_in_basket() { fn all_fruit_types_in_basket() {
let mut basket = get_fruit_basket(); let mut basket = get_fruit_basket();

View File

@ -14,8 +14,6 @@
// Execute `rustlings hint hashmaps3` or use the `hint` watch subcommand for a // Execute `rustlings hint hashmaps3` or use the `hint` watch subcommand for a
// hint. // hint.
// I AM NOT DONE
use std::collections::HashMap; use std::collections::HashMap;
// A structure to store the goal details of a team. // A structure to store the goal details of a team.
@ -34,11 +32,20 @@ fn build_scores_table(results: String) -> HashMap<String, Team> {
let team_1_score: u8 = v[2].parse().unwrap(); let team_1_score: u8 = v[2].parse().unwrap();
let team_2_name = v[1].to_string(); let team_2_name = v[1].to_string();
let team_2_score: u8 = v[3].parse().unwrap(); let team_2_score: u8 = v[3].parse().unwrap();
// TODO: Populate the scores table with details extracted from the // init
// current line. Keep in mind that goals scored by team_1 let team1 = scores.entry(team_1_name).or_insert(Team {
// will be the number of goals conceded from team_2, and similarly goals_scored: 0,
// goals scored by team_2 will be the number of goals conceded by goals_conceded: 0,
// team_1. });
(*team1).goals_scored += team_1_score;
(*team1).goals_conceded += team_2_score;
let team2 = scores.entry(team_2_name).or_insert(Team {
goals_scored: 0,
goals_conceded: 0,
});
(*team2).goals_scored += team_2_score;
(*team2).goals_conceded += team_1_score;
} }
scores scores
} }

View File

@ -20,8 +20,6 @@
// //
// No hints this time! // No hints this time!
// I AM NOT DONE
pub enum Command { pub enum Command {
Uppercase, Uppercase,
Trim, Trim,
@ -31,12 +29,20 @@ pub enum Command {
mod my_module { mod my_module {
use super::Command; use super::Command;
// TODO: Complete the function signature! pub fn transformer(input: Vec<(String, Command)>) -> Vec<String> {
pub fn transformer(input: ???) -> ??? { let mut output: Vec<String> = vec![];
// TODO: Complete the output declaration!
let mut output: ??? = vec![];
for (string, command) in input.iter() { for (string, command) in input.iter() {
// TODO: Complete the function body. You can do it! match command {
Command::Uppercase => output.push(string.to_uppercase()),
Command::Trim => output.push(string.trim().into()),
Command::Append(len) => {
let mut str: String = string.into();
for _ in 0..*len {
str.insert_str(str.len(), "bar");
}
output.push(str.into())
}
}
} }
output output
} }
@ -45,7 +51,7 @@ mod my_module {
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
// TODO: What do we need to import to have `transformer` in scope? // TODO: What do we need to import to have `transformer` in scope?
use ???; use super::my_module::transformer;
use super::Command; use super::Command;
#[test] #[test]