二刷代码随想录训练营Day 46|647. 回文子串、516.最长回文子序列、动态规划总结篇

news2024/9/20 7:53:47

1.回文子串

代码随想录 (programmercarl.com)

视频:动态规划,字符串性质决定了DP数组的定义 | LeetCode:647.回文子串_哔哩哔哩_bilibili

代码:

class Solution {
public:
    int countSubstrings(string s) {
        vector<vector<bool>>dp(s.size(),vector<bool>(s.size(), false));
        int result = 0;
        for(int i = s.size() - 1; i >= 0; i--){
            for(int j = i; j < s.size(); j++){
                if(s[i] == s[j]){
                    if(j - i <= 1){
                        dp[i][j] = true;
                        result++;
                    }else if(dp[i + 1][j - 1] == true){
                        dp[i][j] = true;
                        result++;
                    }
                }
            }
        }
        return result;
    }
};

 note:

为了实现递推,拥有这种递推关系,最好是如果判断两端的元素相等,且两端内的字符串本身就是回文子串,就证明现在的子串也是回文子串,从而实现了递推关系。

dp数组的含义:dp[i][j]表示下标为[i,j]的字符串是否为回文子串

递推公式:

 if(s[i] == s[j]){
     if(j - i <= 1){
        dp[i][j] = true;
        result++;
    }else if(dp[i + 1][j - 1] == true){
        dp[i][j] = true;
        result++;
    }
}

dp数组的初始化:为了不影响计算,全部初始化为false

遍历顺序:根据递推公式,可知,我们要从下往上,从左往右遍历

2.最长回文子序列

代码随想录 (programmercarl.com)

视频:动态规划再显神通,LeetCode:516.最长回文子序列_哔哩哔哩_bilibili

代码:

class Solution {
public:
    int longestPalindromeSubseq(string s) {
        vector<vector<int>> dp(s.size(),vector<int>(s.size(),0));
        for(int i = 0; i < s.size(); i++){
            dp[i][i] = 1;
        }
        for(int i = s.size() - 1; i >= 0; i--){
            for(int j = i + 1; j < s.size(); j++){
                if(s[i] == s[j]){
                    dp[i][j] = dp[i + 1][j - 1] + 2;
                }else{
                    dp[i][j] = max(dp[i + 1][j], dp[i][j - 1]);
                }
            }
        }
        return dp[0][s.size() - 1];
    }
};

 note:

dp数组的含义:下标为[i,j]的最长回文子序列的长度为dp[i][j]

递推公式:

if(s[i] == s[j]){
    dp[i][j] = dp[i + 1][j - 1] + 2;
}else{
    dp[i][j] = max(dp[i + 1][j], dp[i][j - 1]);
}

注意子序列不必连续!

dp数组的初始化:将下标为[i,i]的元素全部初始化为1

遍历顺序:

 根据递推公式,可知,我们要从下往上,从左往右遍历

3.动态规划总结

代码随想录 (programmercarl.com)

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

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

相关文章

Unet改进12:添加PCONV||减少冗余计算和同时存储访问

本文内容:添加PCONV 目录 论文简介 1.步骤一 2.步骤二 3.步骤三 4.步骤四 论文简介 为了设计快速的神经网络,许多工作都集中在减少浮点运算(FLOPs)的数量上。然而,我们观察到FLOPs的这种减少并不一定会导致类似程度的延迟减少。这主要源于低效率的每秒浮点操作数(FLOP…

[数据集][目标检测]课堂行行为检测数据集VOC+YOLO格式4065张12类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;4065 标注数量(xml文件个数)&#xff1a;4065 标注数量(txt文件个数)&#xff1a;4065 标注…

华为云征文|基于Flexus云服务器X实例体验大模型部署体验测评

&#x1f534;大家好&#xff0c;我是雄雄&#xff0c;欢迎关注微信公众号&#xff1a;雄雄的小课堂 先看这里 前言部署千问大模型 前言 当下&#xff0c;各种大模型层出不穷&#xff0c;先有openai的chatgpt&#xff0c;后有百度文心一言&#xff0c;再就是国内大模型齐头并进…

Java:Period和During

文章目录 Period常用方法代码 During常用方法代码 Period 用于计算两个LocalDate对象 相差的年数&#xff0c;月数&#xff0c;天数 常用方法 代码 package NewTime;import java.time.LocalDate; import java.time.Period;/*** Author: ggdpzhk* CreateTime: 2024-08-31*/ p…

新的打包工具 Rsbuild 尝鲜:Vue2-cli 项目迁移 Rsbuild

当前时间 2024-08-31 看到一个新的打包工具&#xff0c;于是想试一试&#xff0c;这里是官网 测试 用过 vue-cli 的同志们应该有所感受&#xff0c;启动项目挺慢的&#xff0c;我这个项目不太大&#xff0c;第一次启动是最慢的&#xff0c;之后启动快了一些些&#xff0c;而且…

【大数据算法】时间亚线性算法之:时间亚线性判定算法概述。

时间亚线性判定算法概述 1、引言2、空间亚线性算法2.1 定义2.2 实现方式2.3 应用场景2.3.1 大数据分析2.3.2 流数据处理2.3.3 近似计算2.3.4 稀疏数据操作 2.4 代码示例 3、总结 1、引言 小屌丝&#xff1a;鱼哥&#xff0c;最近看新闻没啊&#xff1f; 小鱼&#xff1a;我天天…

【无人机设计与控制】使用 SimMechanics 在 Simulink 中仿真四旋翼飞行器

摘要 本文介绍了如何在Simulink中使用SimMechanics模块对四旋翼无人机进行仿真。通过构建详细的机械模型&#xff0c;用户可以模拟四旋翼的物理运动和动力学行为。这种仿真方法不仅适用于研究无人机的飞行性能&#xff0c;还可以用于测试控制系统的有效性和稳定性。 理论 Si…

用 CSS 实现太阳系运行效果

介绍实现最终效果结语介绍 在编程的浩瀚宇宙中,我们总是在探索能够以最简洁的方式创造出最酷炫效果的方法。而使用 CSS 制作响应式太阳系,绝对能提升你的编程乐趣。 如何用 CSS 实现这个神奇的太阳系呢?关键在于巧妙运用 CSS 的动画、定位和尺寸属性。通过定义不同的元素来…

【深入理解SpringCloud微服务】深入理解nacos配置中心(一)——宏观理解nacos配置中心原理

【深入理解SpringCloud微服务】深入理解nacos配置中心&#xff08;一&#xff09;——宏观理解nacos配置中心原理 简单介绍原理分析客户端启动服务端启动配置新增或修改客户端监听配置变更并刷新 nacos既是一个注册中心也是一个配置中心&#xff0c;它是二合一的。作为注册中心…

c# 笔记 winform添加右键菜单,获取文件大小 ,多条件排序OrderBy、ThenBy,list<double>截取前5个

Winform右键菜单‌ 要在C# Winform应用程序中添加右键菜单&#xff0c;‌你可以按照以下步骤操作&#xff1a;‌ 1.‌创建菜单项‌ 在Form的构造函数或加载事件中&#xff0c;‌创建ContextMenuStrip控件的实例&#xff0c;‌并为其添加菜单项。‌ 2.‌绑定到控件‌ 将Con…

YOLOv9修改检测框颜色,粗细,标签大小,标签名称

在检测结果图中&#xff0c;官方的检测样式可能不满足我们的需求&#xff0c;常常修改更改检测框的颜色&#xff0c;粗细&#xff0c;标签背景颜色&#xff0c;大小&#xff0c;标签名称等内容&#xff0c;下面就介绍一下&#xff0c;这些地方如何修改。 在YOLOv9的源代码中&a…

基于ssm的实习课程管理系统/在线课程系统

实习课程管理系统 摘 要 互联网的快速发展&#xff0c;给各行各业带来不同程度的影响&#xff0c;悄然改变人们的生活、工作方式&#xff0c;也倒逼很多行业创新和变革&#xff0c;以适应社会发展的变化。人们为了能够更加方便地管理项目任务&#xff0c;实习课程管理系统被人们…

视频和音频合成视频Easy_Wav2Lip

Easy_Wav2Lip 是使用视频和音频合成新的视频 Easy-WAV2lip是目前最成熟的数字人口型算法。 用时以及效率来说&#xff0c;三大主流算法 WAV2lip、Geneface、AD-Nerf。WAV2lip&#xff1e;Geneface&#xff1d;AD-Nerf 1. 整体流程 第一步&#xff0c;加载视频/图片和音频/tts。…

喵喵在CSDN的2048天(创作纪念日)

大家好&#xff0c;我是爱编程的喵喵。双985硕士毕业&#xff0c;现担任全栈工程师一职&#xff0c;热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。…

OJ-0830**

题目 示例1 输入&#xff1a; ABC ABC 输出&#xff1a; 3示例2 输入&#xff1a; ABCABBA CBABAC 输出&#xff1a; 9解题思路 动态规划 首先&#xff0c;我们可以定义一个二维数组 dp&#xff0c;其中 dp[i][j] 表示从字符串A的前i个字符到字符串B的前j个字符的最短距离。…

DDR3详解

1.DDR3简介 DDR3 SDRAM&#xff0c;全称第三代双倍速率同步动态随机存取存储器&#xff0c;简称 DDR3&#xff0c;双倍速率&#xff08;double-data-rate&#xff09;&#xff0c;是指时钟的上升沿和下降沿都发生数据传输&#xff1b;同步&#xff0c;是指DDR3数据的读取写入是…

Linux教程六:文件目录类命令ls、cd(图文详解)

默认登录出现一个[用户localhost ~] 代表时登陆用户的家目录 1、 Linux ls命令 基本用法 ls&#xff1a;列出当前目录下的文件和目录&#xff08;不包括以.开头的隐藏文件&#xff09;。ls 目录名&#xff1a;列出指定目录下的文件和目录。 常用选项 -l&#xff1a;以长格式列出…

利用开源 AI 智能名片 O2O 商城系统提升饭店私域流量

摘要&#xff1a;本文旨在探讨如何通过设计门店裂变方式&#xff0c;结合开源 AI 智能名片 O2O 商城系统&#xff0c;将私域流量转化为自然流量&#xff0c;以促进饭店业务增长。通过在餐桌上放置个人微信二维码台卡、提供福利套餐和折扣、创建饭圈社群等方式&#xff0c;吸引用…

Vue.js入门系列(十九):深入理解和应用组件自定义事件

个人名片 &#x1f393;作者简介&#xff1a;java领域优质创作者 &#x1f310;个人主页&#xff1a;码农阿豪 &#x1f4de;工作室&#xff1a;新空间代码工作室&#xff08;提供各种软件服务&#xff09; &#x1f48c;个人邮箱&#xff1a;[2435024119qq.com] &#x1f4f1…

python-奥运奖牌计数

题目描述 2008 年北京奥运会&#xff0c;A 国的运动员参与了 n 天的决赛项目 (1≤n≤100)。现在要统计一下 A 国所获得的金、银、铜牌数目及总奖牌数。输入第 1 行是 A 国参与决赛项目的天数 n&#xff0c;其后 n 行&#xff0c;每一行是该国某一天获得的金、银、铜牌数目&…