Python最长递增子序列代码
时间: 2023-12-25 15:28:06 浏览: 80
以下是Python的最长递增子序列代码:
```python
def lis(arr):
n = len(arr)
m = [0]*n
for x in range(n-2,-1,-1):
for y in range(n-1,x,-1):
if arr[x] < arr[y] and m[x] <= m[y]:
m[x] += 1
max_value = max(m)
result = []
for i in range(n):
if m[i] == max_value:
result.append(arr[i])
max_value -= 1
return result
arr = [10, 22, 9, 33, 21, 50, 41, 60, 80]
print(lis(arr))
```
该代码使用动态规划算法来解决最长递增子序列问题。它首先创建一个长度为n的数组m,其中m[i]表示以arr[i]结尾的最长递增子序列的长度。然后,它使用两个嵌套的循环来计算m数组中的每个元素。对于每个元素x,它将从x+1到n-1的所有元素y与x进行比较。如果arr[x] < arr[y]且m[x] <= m[y],则将m[x]的值增加1。最后,它找到m数组中的最大值,并使用它来构建最长递增子序列。
相关问题
python 最长递增子序列
Python中求最长递增子序列的代码可以有多种实现方式。引用\[1\]中给出了一种实现方式,使用了动态规划的思想。该代码定义了一个函数`lis`,接受一个整数数组作为参数。它首先初始化一个长度为数组长度的列表`m`,用于记录以每个元素结尾的最长递增子序列的长度。然后通过两层循环遍历数组,如果当前元素比后面的元素小且以当前元素结尾的子序列长度小于等于以后面元素结尾的子序列长度,则更新以当前元素结尾的子序列长度。最后找到`m`列表中的最大值,然后遍历数组,将与最大值相等的元素添加到结果列表中,并递减最大值,直到最大值为0。最后返回结果列表。给定的示例数组为`\[10, 22, 9, 33, 21, 50, 41, 60, 80\]`,调用`lis`函数后输出结果为`\[10, 22, 33, 50, 60, 80\]`。
另外,引用\[2\]中给出了另一种实现方式,使用了动态规划和二分查找的思想。该代码定义了一个类`Solution`,其中包含一个方法`lengthOfLIS`,接受一个整数数组作为参数。它首先判断数组是否为空,如果为空则返回0。然后初始化一个长度为数组长度的列表`dp`,用于记录以每个元素结尾的最长递增子序列的长度。通过两层循环遍历数组,如果当前元素比前面的元素大,则更新以当前元素结尾的子序列长度为前面元素结尾的子序列长度加1。最后返回`dp`列表中的最大值。这种实现方式的时间复杂度为O(n)。
#### 引用[.reference_title]
- *1* [Python 最长递增子序列代码](https://blog.csdn.net/deanhj/article/details/101634446)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* *3* [最长连续序列 python](https://blog.csdn.net/dearzhuiyi/article/details/126930325)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
Python 最长递增子序列
最长递增子序列是指在一个序列中找到一个最长的子序列,使得子序列中的元素按照递增的顺序排列。下面是一个Python的实现示例:
```python
def lengthOfLIS(nums):
if not nums:
return 0
dp = [1] * len(nums)
for i in range(len(nums)):
for j in range(i):
if nums[i] > nums[j]:
dp[i] = max(dp[i], dp[j] + 1)
return max(dp)
nums = [10, 9, 2, 5, 3, 7, 101, 18]
print(lengthOfLIS(nums)) # 输出:4
```
上述代码中,我们使用动态规划的思想来解决这个问题。我们定义一个dp数组,其中dp[i]表示以第i个元素结尾的最长递增子序列的长度。然后我们遍历数组,对于每个元素,我们再次遍历它之前的元素,如果找到一个比当前元素小的元素,就更新dp[i]为dp[j]+1,其中j表示之前的元素。最后,我们返回dp数组中的最大值作为结果。
阅读全文