![](https://img-blog.csdnimg.cn/img_convert/3232f43b174700062138958d8ffa59e9.png)
分析:
定义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();
}