最长上升子序列(一)

分析:

定义new dp[n],dp[i]代表以i结尾的最长子序列的长度,

以i为结尾,从0到i-1为下标对arr[j]进行遍历,如果发现arr[i]>arr[j],

则需要在dp[i]和dp[j]+1之间取最大值。为什么要在两者之间取最大值呐,

因为dp[i]储存的是以arr[i]为结尾的最大上升子序列,而arr[i]>arr[j]保证了子序列是上升的,

当遇到arr[j]<arr[i]时,说明如果arr[j]可以加入到最长子序列的行列,

则子序列长度在dp[j]基础上+1,为什么要在dp[j]基础上+1呐,

因为dp[j]代表的是以arr[j]结尾的最长子序列,

如果把arr[j]加入到以arr[i]结尾的最长子序列中,

就说明arr[i]一定比以arr[j]结尾的最长子序列里面的都大,

并且是成上升趋势的,需要保证dp[j]+1比目前的dp[i]大,

才能取到dp[j]+1,因此在两者之间选一个即可。

代码如下:

    public int LIS (int[] arr) {
        int n=arr.length();
        if(n==0){
        return 0;        
}
for(int i=0;i<n;i++){
    dp[i]=1;
    for(int j=0;j<i;j++){
    if(arr[i]>arr[j]){
    dp[i]=Math.max(dp[i],dp[j]+1);
}
}
}
return Arrays.stream(dp).max().getAsInt();
    }

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值