#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 给定数组的最长严格上升子序列的长度。
# @param arr int整型一维数组 给定的数组
# @return int整型
#
class Solution:
def LIS(self , arr: List[int]) -> int:
# write code here
n=len(arr)
dp=[0]*(n+1)
for i in range(n):
for j in range(i):# i 前面的找到最大
if arr[j]<arr[i]:
dp[i]=max(dp[i],dp[j]) # 前j 个的最大值记录在i
dp[i]+=1
mx=dp[0]
for i in range(1,n):
if mx<dp[i]:
mx=dp[i]
return mx

京公网安备 11010502036488号