forked from black-shadows/LeetCode-Topicwise-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathform-array-by-concatenating-subarrays-of-another-array.cpp
67 lines (63 loc) · 1.71 KB
/
form-array-by-concatenating-subarrays-of-another-array.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
// Time: O(n)
// Space: O(n)
class Solution {
public:
bool canChoose(vector<vector<int>>& groups, vector<int>& nums) {
int pos = 0;
for (const auto& group : groups) {
pos = KMP(nums, group, pos);
if (pos == -1) {
return false;
}
pos += size(group);
}
return true;
}
private:
int KMP(const vector<int>& text, const vector<int>& pattern, int start) {
const auto& prefix = getPrefix(pattern);
int j = -1;
for (int i = start; i < size(text); ++i) {
while (j + 1 > 0 && pattern[j + 1] != text[i]) {
j = prefix[j];
}
if (pattern[j + 1] == text[i]) {
++j;
}
if (j + 1 == size(pattern)) {
return i - j;
}
}
return -1;
}
vector<int> getPrefix(const vector<int>& pattern) {
vector<int> prefix(size(pattern), -1);
int j = -1;
for (int i = 1; i < size(pattern); ++i) {
while (j + 1 > 0 && pattern[j + 1] != pattern[i]) {
j = prefix[j];
}
if (pattern[j + 1] == pattern[i]) {
++j;
}
prefix[i] = j;
}
return prefix;
}
};
// Time: O(n * m)
// Space: O(1)
class Solution2 {
public:
bool canChoose(vector<vector<int>>& groups, vector<int>& nums) {
auto cit = cbegin(nums);
for (const auto& group: groups) {
cit = search(cit, cend(nums), cbegin(group), cend(group));
if (cit == cend(nums)) {
return false;
}
cit += size(group);
}
return true;
}
};