题解 | #最长递增子序列#
C++ 解法
class Solution {
public:
/**
* retrun the longest increasing subsequence
* @param arr int整型vector the array
* @return int整型vector
*/
vector<int> LIS(vector<int>& arr) {
if (arr.size() == 0) return vector<int>{};
vector<int> ans(arr.size(), INT_MAX), maxLen(arr.size(), 1);
ans[0] = arr[0];
int tail = 1;
for (int i = 0; i < arr.size(); ++i) {
int l = 0, r = tail;
while (l != r) {
int mid = ((long long)l + r) >> 1;
if (ans[mid] >= arr[i]) {
r = mid;
} else {
l = mid + 1;
}
}
ans[l] = arr[i];
maxLen[i] = l + 1;
if (l == tail) ++tail;
}
--tail;
while (ans.back() == INT_MAX) {
ans.pop_back();
}
for (int i = arr.size() - 1; i >= 0; --i) {
if (tail + 1 == maxLen[i]) {
ans[tail] = arr[i];
--tail;
}
}
return ans;
}
}; 
京公网安备 11010502036488号