-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathinvalidTransactions.cpp
More file actions
41 lines (38 loc) · 1.29 KB
/
invalidTransactions.cpp
File metadata and controls
41 lines (38 loc) · 1.29 KB
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
// Source: https://leetcode.com/problems/invalid-transactions/
// Author: Miao Zhang
// Date: 2021-04-15
class Solution {
public:
vector<string> invalidTransactions(vector<string>& transactions) {
vector<bool> invalid(transactions.size(), false);
vector<vector<string>> trans;
for (auto t: transactions) {
string item;
vector<string> items;
for (auto c: t) {
if (c == ',') {
items.push_back(item);
item = "";
} else {
item += c;
}
}
items.push_back(item);
trans.push_back(items);
}
for (int i = 0; i < trans.size(); i++) {
if (stoi(trans[i][2]) > 1000) invalid[i] = true;
for (int j = i + 1; j < trans.size(); j++) {
if ((trans[i][0] == trans[j][0]) && abs(stoi(trans[i][1]) - stoi(trans[j][1])) <= 60 && (trans[i][3] != trans[j][3])) {
invalid[i] = true;
invalid[j] = true;
}
}
}
vector<string> res;
for (int i = 0; i < trans.size(); i++) {
if (invalid[i]) res.push_back(transactions[i]);
}
return res;
}
};