forked from black-shadows/LeetCode-Topicwise-Solutions
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmake-array-strictly-increasing.cpp
36 lines (35 loc) · 1.25 KB
/
make-array-strictly-increasing.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
// Time: O(n^2 * logn)
// Space: O(n)
class Solution {
public:
int makeArrayIncreasing(vector<int>& arr1, vector<int>& arr2) {
std::sort(arr2.begin(), arr2.end());
arr2.erase(unique(arr2.begin(), arr2.end()), arr2.end());
unordered_map<int, int> dp = {{0, -1}}; // dp[min_cost] = end_with_val
for (const auto& val1 : arr1) {
unordered_map<int, int> next_dp;
for (const auto& [cost, val] : dp) {
if (val < val1) {
if (!next_dp.count(cost)) {
next_dp[cost] = val1;
} else {
next_dp[cost] = min(next_dp[cost], val1);
}
}
const auto& it = upper_bound(arr2.cbegin(), arr2.cend(), val);
if (it != arr2.cend()) {
if (!next_dp.count(cost + 1)) {
next_dp[cost + 1] = *it;
} else {
next_dp[cost + 1] = min(next_dp[cost + 1], *it);
}
}
}
dp = move(next_dp);
if (dp.empty()) {
return -1;
}
}
return min_element(dp.cbegin(), dp.cend())->first;
}
};