代码随想录算法训练营第五十五天 _ 动态规划_392. 判断子序列、115.不同的子序列。

学习目标:

动态规划五部曲:
① 确定dp[i]的含义
② 求递推公式
③ dp数组如何初始化
④ 确定遍历顺序
⑤ 打印递归数组 ---- 调试
引用自代码随想录!

60天训练营打卡计划!

学习内容:

392. 判断子序列

这个题目就是 1143.最长公共子序列 的变种,最后只需要判断最长公共子序列长度 与 s字符串(给定字符串 s 和 t ,判断 s 是否为 t 的子序列。)长度的关系。

  • 动态规划五步曲:
    ① 确定dp[i][j]的含义 : 在[0, i] 和 [0, j]范围中的最长公共子序列的长度。(指的就是第一行第一列全填充为空,即多申请这么多空间)
    ② 求递推公式 :
    当前行列元素相等:dp[i+1][j+1] = dp[i][j]
    当前行列元素不相等:dp[i+1][j+1] = max(dp[i][j+1],dp[i+1][j]) – 从前一个元素继承公共序列长度
    ③ dp数组如何初始化 : 第一行和第一列都为零。空置。
    ④ 确定遍历顺序 : 从上到下,从左到右
class Solution {public boolean isSubsequence(String s, String t) {int size1 = s.length();int size2 = t.length();int[][] dp = new int[size1+1][size2+1];// 初始化for(int i = 0; i < size1; i++){for(int j = 0; j < size2; j++){if(s.charAt(i) == t.charAt(j))   dp[i+1][j+1] = dp[i][j] + 1;else  dp[i+1][j+1] = Math.max(dp[i+1][j], dp[i][j+1]);}}return dp[size1][size2] == size1;}
}

115.不同的子序列

  • 动态规划五步曲:
    ① 确定dp[i][j]的含义 : 以 i-1 为结尾的 s 中有以 j-1 为结尾的 t 的个数。(指的就是第一行和第一列都置为空)
    ② 求递推公式 : (不是很好理解)
    当前行列元素相等:dp[i+1][j+1] = dp[i][j] + dp[i][j+1] – 目标字符串是拼凑成的序列的数量 + 目标字符串是连续子序列的数量
    当前行列元素不相等:dp[i+1][j+1] = dp[i][j+1] – 目标字符串是连续子序列

(精髓)以下图为例分析上述的递推公式:
其中s为ba时,t为babgba。因为此时行列元素相等,所以递推公式为dp[i+1][j+1] = dp[i][j] + dp[i][j+1] ,其中dp[i][j]代表的是babgba有几个bdp[i][j+1]代表出现了几次完整的ba字符串,此时s[ ]为a,所以babgba中的所有ba字符串可以由2种方式组成,一种是连续的ba字符串,另一种是分散的b加上当前s[ ]的最后一位a,所以共计有4种。正好可以对应递推公式。
在这里插入图片描述

③ dp数组如何初始化 : 第一列为1,第一行除dp[0][0]外都为0。因为列长是目标字符串长度,第一列为空字符,所以第一列为1。
④ 确定遍历顺序 : 从上到下,从左到右

class Solution {public int numDistinct(String s, String t) {int s_size = s.length();int t_size = t.length();int[][] dp = new int[s_size+1][t_size+1];// 初始化// Arrays.fill(dp[0], 1);for (int i = 0; i < s.length() + 1; i++) {dp[i][0] = 1;}for(int i = 0; i < s_size; i++){for(int j = 0; j < t_size; j++){if(s.charAt(i) == t.charAt(j))   dp[i+1][j+1] = dp[i][j] + dp[i][j+1];else dp[i+1][j+1] = dp[i][j+1];}}// for(int i[]: dp){//     for(int j : i)//         System.out.print(j + " ");//     System.out.println(" ");// }return dp[s_size][t_size];}
}

学习时间:

  • 上午两个半小时,整理文档半小时。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/230242.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

消息队列kafka详解:Kafka原理分析总结

一、概述 Kakfa起初是由LinkedIn公司开发的一个分布式的消息系统&#xff0c;后成为Apache的一部分&#xff0c;它使用Scala编写&#xff0c;以可水平扩展和高吞吐率而被广泛使用。目前越来越多的开源分布式处理系统如Cloudera、Apache Storm、Spark等都支持与Kafka集成。 Kaf…

EasyMock介绍及安装方法(亲测可用)

1. EasyMock介绍 Easy Mock是一个可视化&#xff0c;并且能快速生成模拟数据的服务。以项目管理的方式组织Mock List&#xff0c;能帮助我们更好的管理Mock数据&#xff0c;不怕丢失。 2. EasyMock魅力 前后端分离&#xff1a;让前端工程师独立于后端进行开发 增加单元测试…

SGPIO介紹

什么是SGPIO&#xff1f; Serial General Purpose Input Output (SGPIO) is a method to serialize general purpose IO signals. SGPIO defines the communication between an initiator (e.g. a host bus adapter) and a target (e.g. a backplaneholding disk drives). The …

美易官方:投行把脉明年油市,花旗悲观、高盛最看涨

投行把脉明年油市&#xff0c;花旗悲观、高盛最看涨 随着全球经济的逐步复苏&#xff0c;石油市场的走势备受关注。各大投行对明年油市的预测也各不相同&#xff0c;其中花旗集团较为悲观&#xff0c;而高盛集团则最为看涨。 华尔街的预测师们认为明年原油价格有一定的恢复空间…

最小窗口子串算法题——Java解答

题目&#xff1a;最小窗口子串 题目描述&#xff1a; 给你一个字符串 s 和一个字符串 t&#xff0c;返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串&#xff0c;则返回空字符串 ""。 注意&#xff1a; 对于 t 中重复的字符&#xff…

Axure的交互与情形,事件,动作

交互样式 交互样式是指当用户与原型进行交互时&#xff0c;元素所呈现出的视觉效果。在Axure中&#xff0c;可以通过设置交互样式来调整元素在交互过程中的外观&#xff0c;例如改变颜色、大小、位置等。 交互事件 交互事件是指在用户与原型进行交互时触发的动作。在Axure中&…

记录选择计算机专业后的这十二年,感谢当初自己选择了计算机行业

前言 这篇文章是对我这些年工作经历的回顾&#xff0c;您不会通过这篇文章提升自己的技术能力。如果您还未毕业&#xff0c;但是我希望您可以通过我的故事&#xff0c;简单了解这个行业可以能做什么&#xff0c;你可以做些什么。如果您初入此行业&#xff0c;希望我的故事可以…

一次应急响应记录

背景&#xff1a; 周五晚上&#xff0c;我健身完回到宿舍收到qq消息&#xff0c;原来是安全厂商在扫描资产时&#xff0c;发现一批openssh漏洞如下图&#xff1a; 其实我是一名小白&#xff0c;我的第一反应就是升级openssh版本。但是这里问题又来了&#xff0c;我们内网主机是…

Python 自动化之收发邮件(一)

imapclient / smtplib 收发邮件 文章目录 imapclient / smtplib 收发邮件前言一、基本内容二、发送邮件1.整体代码 三、获取邮件1.整体代码 总结 前言 简单给大家写个如何用Python进行发邮件和查看邮件教程&#xff0c;希望对各位有所帮助。 一、基本内容 本文主要分为两部分…

基于ssm在线作业管理系统的设计与实现论文

摘 要 网络技术和计算机技术发展至今&#xff0c;已经拥有了深厚的理论基础&#xff0c;并在现实中进行了充分运用&#xff0c;尤其是基于计算机运行的软件更是受到各界的关注。加上现在人们已经步入信息时代&#xff0c;所以对于信息的宣传和管理就很关键。因此学生作业信息的…

Web Worker的快速理解与简单应用

Web Worker 是一种在浏览器环境中运行的脚本它在主线程之外运行&#xff0c;可以在后台执行计算密集型或需要长时间运行的任务&#xff0c;而不会阻塞主线程的执行。Web Worker 通过在独立的线程中执行&#xff0c;可以提高页面的性能和响应性。 实现流程&#xff1a; 主线程&a…

补题与总结:牛客小白月赛83(B~F)

文章目录 写在最前面的复盘B-小天的魔法&#xff08;贪心 模拟 双指针&#xff09;C-小天的 Minecraft&#xff08;概率&#xff09;D-小天的子序列&#xff08;预处理 排列组合&#xff09;E-小天的贪吃蛇&#xff08;模拟&#xff09;F-小天的 AB&#xff08;结论题&#xff…

举个栗子!Tableau 技巧(261):自由切换图表的背景颜色

数据粉反馈了一个有趣的需求&#xff1a;Tableau 图表的背景颜色可以设置多个&#xff0c;然后按需切换么&#xff1f; 我们知道&#xff0c;图表的背景颜色对于可视化分析呈现来说非常重要。大部分情况下&#xff0c;我们会固定使用一种背景色。 如果确实需要切换图表背景颜…

K8s内容器拓扑图工具

1.背景&#xff1a;随着线上容器越来越多&#xff0c;需要一个可视化的方式展示各个容器之间的拓扑图。 2.需求&#xff1a;轻量级&#xff0c;部署方便。 3.部署 helm repo add groundcover https://helm.groundcover.com/ helm repo update helm install caretta --namespa…

力扣题目学习笔记(OC + Swift) 11

11.盛最多水的容器 给定一个长度为 n 的整数数组 height 。有 n 条垂线&#xff0c;第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线&#xff0c;使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大水量。 说明&#xff1a;你不能倾…

springboot(ssm儿童慈善管理系统 儿童捐赠平台 Java系统

springboot(ssm儿童慈善管理系统 儿童捐赠平台 Java系统 开发语言&#xff1a;Java 框架&#xff1a;ssm/springboot vue JDK版本&#xff1a;JDK1.8&#xff08;或11&#xff09; 服务器&#xff1a;tomcat 数据库&#xff1a;mysql 5.7&#xff08;或8.0&#xff09; 数…

代码随想录算法训练营第二十天 | 二叉搜索树

目录 力扣题目 力扣题目记录 654.最大二叉树 617.合并二叉树 用值 用指针 700.二叉搜索树中的搜索 递归 迭代 98.验证二叉搜索树 总结 力扣题目 用时&#xff1a;2h 1、654.最大二叉树 2、617.合并二叉树 3、700.二叉搜索树中的搜索 4、98.验证二叉搜索树 力扣…

JupyterNotebook VS JupyterLab 如果jupyter安装成功,点击jupyterlab即可进入lab环境

简介 JupyterNotebook 是一个款以网页为基础的交互计算环境&#xff0c;可以创建Jupyter的文档&#xff0c;支持多种语言&#xff0c;包括Python, Julia, R等等。一般来说&#xff0c;如果是使用R语言的话&#xff0c;使用Rstudio居多&#xff0c;使用Python的话&#xff0c;使…

如何快速优化几千万数据量的订单表

前言 为了保证有一个更健康的身体&#xff0c;所以慢慢降低了更新频率&#xff0c;在有了更多休息时间的前提下&#xff0c;思考了一下接下来准备分享的一些内容。 决定在更新一些技术干货的同时&#xff0c;会穿插一些架构知识&#xff0c;放在单独的专栏里面&#xff0c;希…

鸿蒙Js实战,计算器功能开发

场景&#xff1a; 通过动态设置按钮组件button实现计算器的键盘&#xff0c;通过文本text显示计算的表达书&#xff0c;可以计算&#xff0c;-&#xff0c;*&#xff0c;/&#xff0c;可以一个一个移除&#xff0c;可以重置 等。 下面我们开始今天的文章&#xff0c;还是老规…