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

Day 48 动态规划 part14

Day 48 动态规划 part14

  • 解题理解
    • 1143
    • 1035
    • 53

3道题目
1143. 最长公共子序列
1035. 不相交的线
53. 最大子数组和

解题理解

1143

设dp[i][j]为text10: i-1=text20: j-1的最长公共子序列。

class Solution:def longestCommonSubsequence(self, text1: str, text2: str) -> int:n1 = len(text1)n2 = len(text2)dp = [[0] * (n2 + 1) for _ in range(n1 + 1)]for i in range(1, n1 + 1):for j in range(1, n2 + 1):if text1[i - 1] == text2[j - 1]:dp[i][j] = dp[i - 1][j - 1] + 1else:dp[i][j] = max(dp[i - 1][j], dp[i][j - 1])return dp[-1][-1]

1035

这道题几乎可以看作跟上一题一模一样,因为连线不交叉的前提条件是连线数字的相对顺序不变,所以还是一道求最长公共子序列的题。

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

53

这道题之前用贪心做过,这次除了回顾了一下贪心算法,也用动规实现了下。设dp[i]为以i为结尾的最大子数组和,递推公式也比较好想,dp[i] = max(nums[i], dp[i - 1] + nums[i])

class Solution:def maxSubArray(self, nums: List[int]) -> int:if len(nums) == 1:return nums[0]n = len(nums)dp = [0] * ndp[0] = nums[0]res = dp[0]for i in range(1, n):dp[i] = max(nums[i], dp[i - 1] + nums[i])if res < dp[i]:res = dp[i]return res
http://www.lryc.cn/news/213503.html

相关文章:

  • 目标检测与图像识别分类的区别?
  • 群晖设置DDNS (服务商Godaddy被墙 DDNS-GO无法解析 采用自定义脚本方式完成DDNS更新)
  • 博客摘录「 MySQL不区分大小写设置」2023年10月31日
  • 【UE5】如何在UE5.1中创建级联粒子系统
  • SpringCloud(五) Eureka与Nacos的区别
  • C语言 DAY07:预编译,宏,选择性编译,库(静态库,动态库)
  • [EFI]asus strix b760-i 13900F电脑 Hackintosh 黑苹果efi引导文件
  • 力扣383.赎金信
  • CORS的原理以及在Node.js中的使用
  • kotlin实现单例模式
  • 【Java】LinkedList 集合
  • MySQL-Galera-Cluster集群详细介绍
  • JavaScript从入门到精通系列第二十六篇:详解JavaScript中的Math对象
  • u盘直接拔出文件丢失怎么找回?u盘文件恢复办法分享!
  • rust学习-LinkedList
  • 搭上直播快车,文旅迎来了更大爆发期?
  • 【智能座舱系列】- 深度解密小米Hyper OS,华为HarmonyOS区别
  • kafka-consumer-groups.sh
  • 数据仓库-拉链表
  • 【Docker】一些可以直接用的Docker环境
  • Unity2D中瓦片地图的创建与绘制教程
  • 现代的简洁,诠释轻奢的精致!福州中宅装饰,福州装修
  • 运用ChatGPT辅助新手学习躺赢者PRO飞控二次开发示例(2023年10月28日)
  • 【Java】HashCode方法重写注意事项
  • 039-第三代软件开发-PDF阅读器
  • 计算机毕业设计选题推荐-跑腿平台微信小程序/安卓APP-项目实战
  • RocketMQ生产者消息发送出去了,消费者一直接收不到怎么办?(Rocket MQ订阅关系一致性)
  • 使用Golang开发硬件驱动
  • 设计模式(19)命令模式
  • QModelIndex 与QStandardItem相互转换