首页 > 其他 > 详细

[LeetCode]Longest Increasing Subsequence

时间:2015-12-01 09:39:20      阅读:388      评论:0      收藏:0      [点我收藏+]
public class Solution {
    public int lengthOfLIS(int[] nums) {
        int length = nums.length;
        List<Integer> record = new ArrayList<Integer>();
        for (int i = length - 1; i >= 0; i--) {
            int count = 0;
            if (record.isEmpty()) {
                record.add(nums[i]);
                continue;
            }
            for (int j = record.size() - 1; j >= 0; j--) {
                if (nums[i] < record.get(j)) {
                    count = j + 1;
                    break;
                }
            }
            if (record.size() > count) {
                record.set(count, Math.max(nums[i], record.get(count)));
            } else {
                record.add(nums[i]);
            }
        }
        return record.size();
    }
}

 

[LeetCode]Longest Increasing Subsequence

原文:http://www.cnblogs.com/vision-love-programming/p/5009146.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!