-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy patherase_elements.cpp
102 lines (81 loc) · 2.33 KB
/
erase_elements.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
@author: Sir0ga90
@version: 0.1
@date: 04.10.2016
*/
//=============================================
#include <iostream>
#include <iterator>
#include <vector>
#include <map>
#include <random>
#include <ctime>
#include "erase_elements.h"
//=================================================
/*
Common func for erase of elements of containers
in: _map - main map
in: _vec - main vector
*/
void erase(MMap& _map, MVec& _vec){
printSepLine();
cout << "___Here is containers with some erased elements___\n\n";
eraseRandContainerElems(_map, _vec);
printMapAndVec(_map, _vec);
printSepLine();
}
//=================================================
/*
in: _map - main map
in: _vec - main vector
*/
void eraseRandContainerElems(MMap& _map, MVec& _vec){
eraseMapElems(_map);
eraseVecElems(_vec);
}
//=================================================
/*
Erase elements from main map, from first
element to first + random number of elements;
Erase each elemet, not only by key type;
in: _ersMap - main map
*/
void eraseMapElems(MMap& _ersMap){
size_t randNum = getRandNum();
mMIter mIterBgn = _ersMap.begin();
clog << "Random number of erase elements for map is ->" << randNum << endl;
for(size_t i = 0; i < randNum; i++){
mIterBgn->second--;
testToZero(_ersMap, mIterBgn);
}
}
//=================================================
/*
Test if this key type is empty;
If yes - erase it;
in: _m - main map
in: _mit - main map iterator
*/
void testToZero(MMap& _m, mMIter& _mit){
if(_mit->second == 0)
_m.erase(_mit++);
}
//=================================================
/*
Erase elements from main vector, from first
element to first + random number of elements;
in: _ersVec - main vector
*/
void eraseVecElems(MVec & _ersVec){
size_t randNum = getRandNum();
mVIter mIterBgn = _ersVec.begin();
mVIter mIterEnd = _ersVec.begin() + randNum;
clog << "Random number of erase elements for vector is ->" << randNum << endl;
_ersVec.erase(mIterBgn, mIterEnd);
}
//=================================================
size_t getRandNum(void){
srand( time(0) );
return rand() % MAX_ERS_NUM + 1;
}
//=================================================