当前位置: 首页 > news >正文

最长递增子序列 -- 动规

300. 最长递增子序列

注意「⼦序列」和「⼦串」的区别,⼦串⼀定是连续的,⽽⼦序列不⼀定是连续的。

class LengthOfLIS:"""300. 最长递增子序列https://leetcode.cn/problems/longest-increasing-subsequence/description/"""def solution(self, nums: List[int]):"""方案一: 动态规划辅助数组 dp,dp[i] 表示以nums[i]结尾的子序列的最大长度时间复杂度O(N^2)空间复杂度O(N):param nums::return:"""n = len(nums)dp = [1] * nfor i in range(1, n):tmp = 0for j in range(0, i):if nums[j] < nums[i]:tmp = max(tmp, dp[j])dp[i] = tmp + 1return max(dp)def solution2(self, nums: List[int]):"""方案二:动态规划辅助数组 ends,ends[i] 代表目前所有长度为i+1的递增子序列的最小结尾。可推断出 ends 也是递增序列时间复杂度O(N*logN)空间复杂度O(N):param nums::return:"""if not nums:return 0n = len(nums)ends = [0] * nends[0] = nums[0]l, r, m, right = 0, 0, 0, 0res = 1for i in range(1, n):l = 0r = rightwhile l <= r:m = (l + r) // 2if nums[i] > ends[m]:l = m + 1else:r = m - 1print(right, l)right = max(right, l)ends[l] = nums[i]res = max(res, l + 1)return resdef solution3(self, nums: List[int]) -> int:"""模拟蜘蛛纸牌:param nums::return:"""top = [0] * len(nums)#  牌堆数初始化为 0piles = 0for i in range(len(nums)):poker = nums[i]left, right = 0, pileswhile left < right:mid = left + (right - left) // 2if top[mid] > poker:right = midelif top[mid] < poker:left = mid + 1else:right = mid# 没找到合适的牌堆,新建⼀堆if left == piles:piles += 1# 把这张牌放到牌堆顶top[left] = pokerreturn piles
http://www.lryc.cn/news/162188.html

相关文章:

  • linux 进程管理命令
  • 第一章:计算机网络和因特网
  • Android后退堆栈
  • 网络原理(一)网络基础,包括IP ,网络相关的定义
  • Python语义分割与街景识别(2):环境搭建
  • stm32(GD32,apm32),开优化后需要特别注意的地方
  • LLVM 与代码混淆技术
  • R语言---使用runway进行机器学习模型性能的比较
  • C++斩题录|递归专题 | leetcode50. Pow(x, n)
  • 详解Redis之Lettuce实战
  • 【3】单着色器文件读取
  • 祝贺埃文科技入选河南省工业企业数据安全技术支撑单位
  • Chinese-LLaMA-Alpaca-2模型的测评
  • SLAM论文详解(5) — Bundle_Adjustment_LM(BALM)论文详解
  • C语言对单链表所有操作与一些相关面试题
  • 高防服务器如何抵御大规模攻击
  • Go 接口和多态
  • Git忽略文件的几种方法,以及.gitignore文件的忽略规则
  • C语言——指针进阶(2)
  • 【汇编中的寄存器分类与不同寄存器的用途】
  • 基于文本提示的图像目标检测与分割实践
  • 【4-5章】Spark编程基础(Python版)
  • 04 卷积神经网络搭建
  • 【hadoop运维】running beyond physical memory limits:正确配置yarn中的mapreduce内存
  • 数据结构--6.5二叉排序树(插入,查找和删除)
  • 无需公网IP,在家SSH远程连接公司内网服务器「cpolar内网穿透」
  • Java工具类
  • makefile之使用函数wildcard和patsubst
  • 算法通关村第十八关——排列问题
  • 基于STM32设计的生理监测装置