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

河南省交通基本建设质量检测监督站网站青羊区企业网站建设策划

河南省交通基本建设质量检测监督站网站,青羊区企业网站建设策划,大理旅游网站建设,dede 网站地图样式300. 最长递增子序列 给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子…

300. 最长递增子序列

给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。

子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列

思路:由题意得知,子序列是可以删除数组中的元素的,即一段长为s的序列的最长子序列,可能与若干个元素都无关,因此 长度为s的序列的最长子序列的状态依赖于在这之前的所有长度为1,2,3,。。。s-1的状态。转移方程,由于要求的是最长严格递增子序列,那么不难想到,如果当前的元素比遍历到的元素的元素大,那么就可以将其放到该元素的后面,形成一个严格递增子序列。既然如此,dp数组的定义就定义为,dp[i] 为 以 nums[i]结尾的最长子序列,转移方程为 if nums[i] > nums[j], dp[i] = max(dp[i], dp[j] + 1),初始化为1. 使用result来记录dp数组中的最大值。

class Solution:def lengthOfLIS(self, nums: List[int]) -> int:dp = [1 for _ in range(len(nums))]result = 1for i in range(1, len(dp)):for j in range(i):if nums[i] > nums[j]:dp[i] = max(dp[i], dp[j] + 1)result = max(dp[i], result)return result

674. 最长连续递增序列

给定一个未经排序的整数数组,找到最长且 连续递增的子序列,并返回该序列的长度。

连续递增的子序列 可以由两个下标 l 和 rl < r)确定,如果对于每个 l <= i < r,都有 nums[i] < nums[i + 1] ,那么子序列 [nums[l], nums[l + 1], ..., nums[r - 1], nums[r]] 就是连续递增子序列。

思路:与上一题类似,dp[i]的定义为 以nums[i]为结尾的连续递增子序列长度,转移方程为,当nums[i] > nums[i-1], dp[i] = dp[j] + 1, 以result记录dp数组最大值

class Solution:def findLengthOfLCIS(self, nums: List[int]) -> int:dp = [1 for _ in range(len(nums))]result = 1for i in range(1, len(dp)):if nums[i] > nums[i-1]:dp[i] = dp[i-1] + 1result = max(dp[i], result)return result

 718. 最长重复子数组

给两个整数数组 nums1 和 nums2 ,返回 两个数组中 公共的 、长度最长的子数组的长度 

思路:设置dp[i][j] 为 nums1 前i -1个元素 和 nums2 前 j -1个元素 的公共最长重复子数组,那么转移方程为 if nums1[i-1] == nums2[j-1] , dp[i][j] = dp[i-1][j-1], 由于dp数组的设置,遍历时由1开始,len(nums1)+1 结束 (左闭右开)

二维dp

class Solution:def findLength(self, nums1: List[int], nums2: List[int]) -> int:dp = [[0] * (len(nums2) + 1) for _ in range(len(nums1) + 1)]result = 0for i in range(1, len(nums1) + 1):for j in range(1, len(nums2) + 1):if nums1[i-1] == nums2[j-1]:dp[i][j] = dp[i-1][j-1] + 1result = max(result, dp[i][j])return result

一维dp

class Solution:def findLength(self, nums1: List[int], nums2: List[int]) -> int:dp = [0] * (len(nums2) + 1)result = 0# 遍历数组 nums1for i in range(1, len(nums1) + 1):# 倒序遍历数组 nums2for j in range(len(nums2), 0, -1):if nums1[i-1] == nums2[j-1]:dp[j] = dp[j-1] + 1result = max(dp[j], result)else:dp[j] = 0return result

http://www.yayakq.cn/news/922861/

相关文章:

  • 怎么能查到网站是哪家公司做的什么网上平台可以找客源
  • 捡个校花做老婆是哪个网站的免费商城系统哪个好
  • 国外ps设计图网站做教育app的网站有哪些内容
  • 海淘网站建设的目的网络营销的解释
  • 网站备案的影响试析媒体网站品牌建设
  • 怎么做自己的淘宝网站wordpress无法连接数据库
  • 新余建设银行招聘网站自己做卖东西网站
  • 做网站如何把栏目放到首页福州制作网站设计哪里比较好
  • 网站维护外包合同客户管理软件单机版
  • 南昌优秀网站建设网站栏目结构图
  • 国外做美食视频网站电子商务网站建设收益
  • 萤石云网站开发大型网站架设需要考虑哪些问题
  • 网站的开发语言网络架构是什么
  • icp许可证个人网站个人网页在线制作
  • 如何做网站插件管理平台登录
  • 网站搭建怎么弄的微信公众号外链接网站开发
  • 南宁网站开发价格wordpress支持大数据处理
  • php做网站用什么开发工具建设网站八大员成绩查询
  • 网站做零售公司网站建设费用计入什么科目
  • 网站建设流程步骤为需求分析企业的网站设计能否以为导向
  • asp 通过ftp 网站搬家网站建设总计
  • 广州市开发区建设局官方网站网站搭建平台demo免费
  • 门户网站建设情况汇报优秀网页设计作品分析ppt
  • 济宁祥云网站建设软件开发项目内容
  • 泉州企业建站模板合肥app建设公司
  • 做公司网站可以抄别人的吗网站短链接生成
  • 做网站兴趣爱好网站开发asp.net
  • 用dw怎么做用户登录页面的网站网站建设模板一次收费
  • 深圳网站设计clh怎么自己学做电商
  • 上海企业网站制作哪家好天河微网站建设