最长上升子序列

最长上升子序列

输入:[ 10,9,2,5,3,7,101,18 ]
结果:[2,3,7,101 ] 4
时间复杂度:O(nlogN)

static int maxLength(int[] nums){
        int[] dp = new int[nums.length];
        Arrays.fill(dp, 1);
        for (int i = 0; i < nums.length; i++) {
            //后面的
            for (int j = 0; j < i; j++) {
                //前面的
                if (nums[i] > nums[j])
                    //如果前面存在比后面的大的时候,这个最长长度就是i到j的长度
                    dp[i] = Math.max(dp[i], dp[j] + 1);
            }
        }
        int res = 0;
        for (int i = 0; i < dp.length; i++) {
            res = Math.max(res, dp[i]);
        }
        return res;
    }

文章作者: 凌云
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 凌云 !
  目录