题解 | #最长递增子序列# C++ 解法,挺有意思的一道题

最长递增子序列

http://www.nowcoder.com/practice/9cf027bf54714ad889d4f30ff0ae5481

题解 | #最长递增子序列#
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;
    }
};
全部评论

相关推荐

自由水:笑死了,敢这么面试不敢让别人说
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务