"You can make more friends in two months by becoming interested in other people than you can in two years by trying to get other people interested in you." - Dale Carnegie
After reading How to Win Friends and Influence People, Xorin decided that the only way to become an interesting individual (the kind that Xoranna would fancy) was by starting to slowly expand his social horizons, through attempting to experience new and unexpected hobbies.
This was the spark that ignited his passion for football. Aside from playing, Xorin also became an avid follower of tournaments. Our problem issues the most important football event - the World Cup.
Due to his lack of experience, Xorin has no favourite team. As a result, he will only follow the matches that take place in the first group of the championship. Like all other proud romanians (born and raised), he does not particularly enjoy losing, so he will choose to support the group's winning team for the rest of the competition. Your task is to provide him the final standings of the group, after all matches have been played.
Input
After watching all matches, Xorin gives you the result of each match on one line of input, in the following manner:
TeamA TeamB GoalsA GoalsB
Output
The output should respect the following format:
firstTeam secondTeam thirdTeam fourthTeam
where the teams' order is as follows:
- each winning team gets 3 points;
- each match that results in a tie grants both teams 1 point;
- each losing team gets 0 points;
- teams are sorted decreasingly by the number of points they accumulate;
- in case of equal points, multiple teams are sorted decreasingly by the total number of goals they have scored;
- in case of equal points and equal goals, multiple teams are sorted alphabetically, in ascending order.
Constraints
- The group contains 4 teams.
- Each two teams play exactly one match together. There is a total of 6 matches played, thus 6 lines of input.
- Teams' names are made up of exactly one word, containing lowercase and/or uppercase English letters. No two teams share the same name.
- Team names are no longer than 100 characters.
- No team scores more than 10 goals in one match.
- Since Xorin wants to take Xoranna out to the finals, his chances of her saying 'yes' would greatly increase if one of the finalists were the team he supports.
Sample
Input | Output |
---|---|
Brazil Croatia 3 1 Mexico Cameroon 1 0 Brazil Mexico 0 0 Cameroon Croatia 0 4 Cameroon Brazil 1 4 Croatia Mexico 1 3 | Brazil Mexico Croatia Cameroon |
Explanation: fifa.com
The main problem we're dealing with is finding a suitable data structure. First of all, it should allow updating teams' scores and total goals, with every passing match. Secondly, it should facilitate custom sorting, based on the given criteria (number of points > number of goals > team name). Most modern programming languages provide such a data structure: map + vector from C++'s Standard Template Library, or a dictionary in Python.
C++11 solution (Sergiu Puscas)
1 #include <iostream> 2 #include <map> 3 #include <vector> 4 #include <string> 5 #include <algorithm> 6 #define totalPoints first 7 #define totalGoals second 8 #define name first 9 #define stats second 10 using namespace std; 11 12 map <string, pair <int, int>> M; 13 vector <pair <string, pair <int, int>>> v; 14 int goalsA, goalsB, bonusA, bonusB; 15 string teamA, teamB; 16 17 bool cmp(pair <string, pair <int, int>> A, pair <string, pair <int, int>> B) { 18 if(A.stats.totalPoints != B.stats.totalPoints) 19 return A.stats.totalPoints > B.stats.totalPoints; 20 21 if(A.stats.totalGoals != B.stats.totalGoals) 22 return A.stats.totalGoals > B.stats.totalGoals; 23 24 return A.name < B.name; 25 } 26 27 int main() { 28 for(int i=1; i<=6; i++) { 29 cin>>teamA>>teamB>>goalsA>>goalsB; 30 31 if(goalsA > goalsB) bonusA = 3, bonusB = 0; 32 else if(goalsA == goalsB) bonusA = 1, bonusB = 1; 33 else bonusA = 0, bonusB = 3; 34 35 if(M.find(teamA) == M.end()) M[teamA] = make_pair(0, 0); 36 if(M.find(teamB) == M.end()) M[teamB] = make_pair(0, 0); 37 38 M[teamA] = make_pair(M[teamA].totalPoints + bonusA, M[teamA].totalGoals + goalsA); 39 M[teamB] = make_pair(M[teamB].totalPoints + bonusB, M[teamB].totalGoals + goalsB); 40 } 41 42 for(auto team:M) v.push_back(team); 43 sort(v.begin(), v.end(), cmp); 44 for(auto team:v) cout<<team.name<<"\n"; 45 46 return 0; 47 }
Python solution
1 scoreboard, goalboard = {}, {} 2 3 for _ in range(0, 6): 4 teamA, teamB, goalsA, goalsB = raw_input().split() 5 goalsA, goalsB = map(int, [goalsA, goalsB]) 6 7 if goalsA > goalsB: scoreA, scoreB = 3, 0 8 elif goalsA == goalsB: scoreA, scoreB = 1, 1 9 else: scoreA, scoreB = 0, 3 10 11 if not teamA in scoreboard: scoreboard[teamA], goalboard[teamA] = 0, 0 12 if not teamB in scoreboard: scoreboard[teamB], goalboard[teamB] = 0, 0 13 14 scoreboard[teamA] += scoreA 15 scoreboard[teamB] += scoreB 16 17 goalboard[teamA] += goalsA 18 goalboard[teamB] += goalsB 19 20 print '\n'.join(["%s" % x[2] for x in sorted([(scoreboard[x], goalboard[x], x) for x in scoreboard], key=lambda x: (-x[0], -x[1], x[2]))])