forked from luliyucoordinate/Leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1169.cpp
39 lines (38 loc) · 1.22 KB
/
1169.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
class Solution
{
public:
vector<string> invalidTransactions(vector<string>& transactions)
{
unordered_map<string, vector<tuple<int, string, int>>> data;
unordered_set<int> delt;
for (int i = 0; i < transactions.size(); ++i)
{
stringstream ss(transactions[i]);
vector<string> s(4, "");
int k = 0;
while (getline(ss, s[k++], ','));
if (stoi(s[2]) > 1000) delt.insert(i);
data[s[0]].push_back({stoi(s[1]), s[3], i});
}
for (auto& it : data)
{
sort(it.second.begin(), it.second.end());
deque<tuple<int, string, int>> q;
for (auto& t1 : it.second)
{
while (!q.empty() and get<0>(q.front()) < get<0>(t1) - 60) q.pop_front();
for (auto& t2 : q)
{
if (get<1>(t1) != get<1>(t2))
{
delt.insert(get<2>(t1)); delt.insert(get<2>(t2));
}
}
q.emplace_back(t1);
}
}
vector<string> res;
for (auto& i : delt) res.push_back(transactions[i]);
return res;
}
};