// A list of scores (one per line) of a soccer match is given. Each line is of // the form ",,," // Example: "England,France,4,2" (England scored 4 goals, France 2). // // You have to build a scores table containing the name of the team, the total // number of goals the team scored, and the total number of goals the team // conceded. use std::collections::HashMap; // A structure to store the goal details of a team. #[derive(Default)] struct TeamScores { goals_scored: u8, goals_conceded: u8, } fn build_scores_table(results: &str) -> HashMap<&str, TeamScores> { // The name of the team is the key and its associated struct is the value. let mut scores = HashMap::new(); for line in results.lines() { let mut split_iterator = line.split(','); // NOTE: We use `unwrap` because we didn't deal with error handling yet. let team_1_name = split_iterator.next().unwrap(); let team_2_name = split_iterator.next().unwrap(); let team_1_score: u8 = split_iterator.next().unwrap().parse().unwrap(); let team_2_score: u8 = split_iterator.next().unwrap().parse().unwrap(); } scores } fn main() { // You can optionally experiment here. } #[cfg(test)] mod tests { use super::*; const RESULTS: &str = "England,France,4,2 France,Italy,3,1 Poland,Spain,2,0 Germany,England,2,1 England,Spain,1,0"; #[test] fn build_scores() { let scores = build_scores_table(RESULTS); } #[test] fn validate_team_score_1() { } #[test] fn validate_team_score_2() { } }