forked from jaege/Cpp-Primer-5th-Exercises
-
Notifications
You must be signed in to change notification settings - Fork 0
/
11.23.cpp
53 lines (45 loc) · 1.66 KB
/
11.23.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
#include <string>
#include <map>
#include <vector>
#include <iostream>
typedef std::multimap<std::string, std::vector<std::string>> family_type;
void addFamily(family_type &families, const std::string &name) {
families.insert({name, std::vector<std::string>()}); // always insert value
//auto ret = families.insert({name, std::vector<std::string>()});
//if (!ret.second)
// std::cerr << "Error: Already has family <" << name << ">" << std::endl;
}
void addChild(family_type &families, const std::string &family_name,
const std::string &child_name) {
auto it = families.find(family_name);
if (it != families.end())
it->second.push_back(child_name);
else
std::cerr << "Error: No family <" << family_name << "> for child <"
<< child_name << ">" << std::endl;
}
int main() {
family_type families;
addFamily(families, "Zhang");
addFamily(families, "Li");
addFamily(families, "Wang");
addChild(families, "Zhang", "San");
addChild(families, "Zhang", "Bao");
addChild(families, "Zhang", "Tian");
addChild(families, "Li", "Si");
addChild(families, "Wang", "Wu");
addChild(families, "Wang", "San");
addChild(families, "Zhao", "Liu"); // Error
addFamily(families, "Zhang");
// OK, but the following two statement will add to the first "Zhang" key,
// because we use `find()` to find the first present key.
addChild(families, "Zhang", "Mei");
addChild(families, "Zhang", "Lu");
for (const auto &family : families) {
std::cout << family.first << "'s family:" << std::endl;
for (const auto &name : family.second)
std::cout << family.first << " " << name << std::endl;
std::cout << std::endl;
}
return 0;
}