-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathalphabet_war.cpp
64 lines (47 loc) · 1.3 KB
/
alphabet_war.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
//Introduction
//There is a war and nobody knows - the alphabet war!
//There are two groups of hostile letters. The tension between left side letters and right side letters was too high and the war began.
//Task
//Write a function that accepts fight string consists of only small letters and return who wins the fight. When the left side wins return Left side wins!, when the right side wins return Right side wins!, in other case return Let's fight again!.
//The left side letters and their power:
// w - 4
// p - 3
// b - 2
// s - 1
//The right side letters and their power:
// m - 4
// q - 3
// d - 2
// z - 1
//The other letters don't have power and are only victims.
#include <string>
#include <map>
using namespace std;
string alphabetWar(string fight)
{
map<char, int> leftSide = {
{'w', 4},
{'p', 3},
{'b', 2},
{'s', 1},
};
map<char, int> rightSide = {
{'m', 4},
{'q', 3},
{'d', 2},
{'z', 1},
};
int leftPoints = 0, rightPoints = 0;
for (auto c : fight)
{
if (leftSide.count(c))
leftPoints += leftSide[c];
if (rightSide.count(c))
rightPoints += rightSide[c];
}
if (leftPoints > rightPoints)
return "Left side wins!";
if (rightPoints > leftPoints)
return "Right side wins!";
return "Let's fight again!";
}