forked from pezy/CppPrimer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathex17_05_findBook.h
62 lines (56 loc) · 2.21 KB
/
ex17_05_findBook.h
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
#pragma once
#include <algorithm>
#include <iostream>
#include <numeric>
#include <string>
#include <utility>
#include <vector>
#include "../ch14/ex14_45_sales_data.h"
using std::pair;
using std::vector;
using std::string;
using std::make_pair;
namespace EX05 {
using matches = pair<vector<Sales_data>::size_type,
pair<vector<Sales_data>::const_iterator,
vector<Sales_data>::const_iterator>>;
vector<matches> findBook(const vector<vector<Sales_data>>& files,
const string& book)
{
vector<matches> ret; // initally empty
// for each store find the range of matching books, if any
for (auto it = files.cbegin(); it != files.cend(); ++it) {
// find the range of Sales_data that have the same ISBN
auto found =
std::equal_range(it->cbegin(), it->cend(), Sales_data(book),
[](const Sales_data& sd1, const Sales_data& sd2) {
return sd1.isbn() < sd2.isbn();
});
if (found.first != found.second) // this store had sales
// remember the index of this store and the matching range
ret.push_back(make_pair(it - files.cbegin(),
make_pair(found.first, found.second)));
}
return ret; // empty if no matches found
}
void reportResults(std::istream& in, std::ostream& os,
const vector<vector<Sales_data>>& files)
{
string s;
while (std::cout << "Enter the book ISBN to look for: ", in >> s) {
auto trans = findBook(files, s); // stores that sold this book
if (trans.empty()) {
std::cout << s << " not found in any stores." << std::endl;
continue; // get the next book to look for
}
for (auto&& store : trans) { // // for every store with a sale
// get<n> returns the specified member from the tuple in store
os << "store " << store.first + 1 << " sales: "
<< std::accumulate(store.second.first, store.second.second,
Sales_data(s))
<< std::endl;
}
std::cout << "----" << std::endl;
}
}
} // namespace EX05