代码随想录算法训练营第五十七天 647. 回文子串、516.最长回文子序列、动态规划章节总结

本文主要是介绍代码随想录算法训练营第五十七天 647. 回文子串、516.最长回文子序列、动态规划章节总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码随想录算法训练营第五十七天 | 647. 回文子串、516.最长回文子序列、动态规划章节总结

647. 回文子串

题目链接:647. 回文子串 - 力扣(LeetCode)

// dp法
class Solution {public int countSubstrings(String s) {int len = s.length();int count = 0;/**当s[i] != s[j]时,那没啥好说的了,dp[i][j]一定是false。当s[i] == s[j]时,这就复杂一些了,有如下三种情况情况一:下标i 与 j相同,同一个字符例如a,当然是回文子串情况二:下标i 与 j相差为1,例如aa,也是回文子串情况三:下标:i 与 j相差大于1的时候,例如cabac,此时s[i]与s[j]已经相同了,我们看i到j区间是不是回文子串就看aba是不是回文就可以了,那么aba的区间就是 i+1 与 j-1区间,这个区间是不是回文就看dp[i + 1][j - 1]是否为true*/// dp[i][j] 表示子字符串(下表范围[i, j])) 是否是回文boolean[][] dp = new boolean[len][len];// 初始化 :dp[i][j] 全部初始化为falsefor(int i = len - 1; i >= 0; --i) {for(int j = i; j < len; ++j) {// 只有在这种情况下,才能if(s.charAt(i) == s.charAt(j)) { // 情况一 和 情况二if(j - i <= 1) {dp[i][j] = true;count++;// 情况三} else if (dp[i+1][j-1]) {dp[i][j] = true;count++;}}}}return count;}
}// 双指针法
}class Solution {public int countSubstrings(String s) {int len, ans = 0;if (s == null || (len = s.length()) < 1) return 0;for(int i = 0; i < len; ++i) {ans += extend(s, i, i, len); // 以i为中心点ans += extend(s, i, i+1, len); // 以i和i+1为中心点}return ans;}int extend(String s, int i, int j, int n) {int res = 0;while (i >= 0 && j < n && s.charAt(i) == s.charAt(j)) {i--;j++;res++;}return res;}
}

516.最长回文子序列

题目链接:516. 最长回文子序列 - 力扣(LeetCode)

class Solution {public int longestPalindromeSubseq(String s) {int len = s.length();// dp[i][j] 表示 [i, j] 范围中最长的回文子序列长度int[][] dp = new int[len][len];for(int i = len - 1; i >= 0; --i) {dp[i][i] = 1; // 初始化for(int j = i + 1; j < len; ++j) {if(s.charAt(i) == s.charAt(j)) {dp[i][j] = dp[i+1][j-1] + 2; // 相等时,可以使[i+1,j-1]内最长回文子序列的长度+2} else {dp[i][j] = Math.max(dp[i+1][j], dp[i][j-1]); // 不相等,则只能在[i+1, j]和[i, j-1]中选一个最长的回文子序列长度}}}return dp[0][len - 1];}
}

动态规划章节总结

动规五部曲分别为:

  1. 确定dp数组(dp table)以及下标的含义

  2. 确定递推公式

  3. dp数组如何初始化

  4. 确定遍历顺序

  5. 举例推导dp数组

  • 背包问题
  • 打家劫舍系列
  • 股票系列
  • 子序列系列

这篇关于代码随想录算法训练营第五十七天 647. 回文子串、516.最长回文子序列、动态规划章节总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/799269

相关文章

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

jupyter代码块没有运行图标的解决方案

《jupyter代码块没有运行图标的解决方案》:本文主要介绍jupyter代码块没有运行图标的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录jupyter代码块没有运行图标的解决1.找到Jupyter notebook的系统配置文件2.这时候一般会搜索到

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++