题解 | #最长上升子序列(三)#

最长上升子序列(三)

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

先贴上代码,有时间再来注解~

class Solution {
public:
    /**
     * retrun the longest increasing subsequence
     * @param arr int整型vector the array
     * @return int整型vector
     */
    vector<int> LIS(vector<int>& arr) {
        int n = arr.size();
        if (n == 0) {
            return {};
        }
        int maxLen = 0;
        vector<int> tails(n);
        vector<int> maxArr(n);
        for (int i = 0; i < n; i++) {
            int left = 0, right = maxLen - 1;
            while (left <= right) {
                int mid = left + ((right - left) >> 1);
                if (tails[mid] < arr[i]) {
                    left = mid + 1;
                } else {
                    right = mid - 1;
                }
            }
            tails[left] = arr[i];
            maxArr[i] = left + 1;
            if (left == maxLen) {
                maxLen++;
            }
        }
        
        vector<int> res(maxLen);
        int len = maxLen;
        for (int i = n - 1; i >= 0; i--) {
            if (maxArr[i] == len) {
                res[--len] = arr[i];
            }
        }
        return res;
    }
};
全部评论

相关推荐

头像
11-09 12:17
清华大学 C++
out11Man:小丑罢了,不用理会
点赞 评论 收藏
分享
废铁汽车人:秋招真是牛鬼蛇神齐聚一堂
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务