From cc412f875674af9a97a048d30a6bacb41dc5d3c1 Mon Sep 17 00:00:00 2001 From: liruifengv Date: Sun, 6 Nov 2022 17:25:33 +0800 Subject: [PATCH] hashmaps --- exercises/hashmaps/hashmaps1.rs | 8 +++----- exercises/hashmaps/hashmaps2.rs | 8 +++----- exercises/hashmaps/hashmaps3.rs | 21 ++++++++++++++------- 3 files changed, 20 insertions(+), 17 deletions(-) diff --git a/exercises/hashmaps/hashmaps1.rs b/exercises/hashmaps/hashmaps1.rs index fd8dd2f8..80b041b6 100644 --- a/exercises/hashmaps/hashmaps1.rs +++ b/exercises/hashmaps/hashmaps1.rs @@ -10,17 +10,15 @@ // // Execute `rustlings hint hashmaps1` or use the `hint` watch subcommand for a hint. -// I AM NOT DONE - use std::collections::HashMap; fn fruit_basket() -> HashMap { - let mut basket = // TODO: declare your hash map here. + let mut basket = HashMap::new(); // Two bananas are already given for you :) basket.insert(String::from("banana"), 2); - - // TODO: Put more fruits in your basket here. + basket.insert(String::from("apple"), 1); + basket.insert(String::from("orange"), 2); basket } diff --git a/exercises/hashmaps/hashmaps2.rs b/exercises/hashmaps/hashmaps2.rs index 454b3e1d..84fa5fa5 100644 --- a/exercises/hashmaps/hashmaps2.rs +++ b/exercises/hashmaps/hashmaps2.rs @@ -11,8 +11,6 @@ // // Execute `rustlings hint hashmaps2` or use the `hint` watch subcommand for a hint. -// I AM NOT DONE - use std::collections::HashMap; #[derive(Hash, PartialEq, Eq)] @@ -34,9 +32,9 @@ fn fruit_basket(basket: &mut HashMap) { ]; for fruit in fruit_kinds { - // TODO: Put new fruits if not already present. Note that you - // are not allowed to put any type of fruit that's already - // present! + if !basket.contains_key(&fruit) { + basket.insert(fruit, 3); + } } } diff --git a/exercises/hashmaps/hashmaps3.rs b/exercises/hashmaps/hashmaps3.rs index 18dd44c9..7eefca93 100644 --- a/exercises/hashmaps/hashmaps3.rs +++ b/exercises/hashmaps/hashmaps3.rs @@ -14,8 +14,6 @@ // Execute `rustlings hint hashmaps3` or use the `hint` watch subcommand for a hint. -// I AM NOT DONE - use std::collections::HashMap; // A structure to store team name and its goal details. @@ -35,15 +33,24 @@ fn build_scores_table(results: String) -> HashMap { let team_1_score: u8 = v[2].parse().unwrap(); let team_2_name = v[1].to_string(); let team_2_score: u8 = v[3].parse().unwrap(); - // TODO: Populate the scores table with details extracted from the - // current line. Keep in mind that goals scored by team_1 - // will be number of goals conceded from team_2, and similarly - // goals scored by team_2 will be the number of goals conceded by - // team_1. + + calc_score(&mut scores, team_1_name, team_1_score, team_2_score); + calc_score(&mut scores, team_2_name, team_2_score, team_1_score); } scores } + +fn calc_score (scores: &mut HashMap, team_name: String, goals_scored: u8, goals_conceded: u8) { + let mut team = scores.entry(team_name.clone()).or_insert(Team { + name: team_name, + goals_scored: 0, + goals_conceded: 0 + }); + team.goals_scored += goals_scored; + team.goals_conceded += goals_conceded; +} + #[cfg(test)] mod tests { use super::*;