代码随想录训练营day57
题目一:回文子串
力扣题目链接
题目描述:
给你一个字符串 s
,请你统计并返回这个字符串中 回文子串 的数目。
回文字符串 是正着读和倒过来读一样的字符串。
子字符串 是字符串中的由连续字符组成的一个序列。
具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被视作不同的子串。
思路分析:代码随想录
- 确定dp数组(dp table)以及下标的含义:布尔类型的dp[i][j]:表示区间范围[i,j] (注意是左闭右闭)的子串是否是回文子串,如果是dp[i][j]为true,否则为false。
- 确定递推公式
- dp数组如何初始化:dp[i][j]初始化为false。
- 确定遍历顺序:从下到上,从左到右遍历
- 举例推导dp数组
解法一:动归
class Solution {public int countSubstrings(String s) {int len, ans = 0;if (s == null || (len = s.length()) < 1) return 0;//dp[i][j]:s字符串下标i到下标j的字串是否是一个回文串,即s[i, j]boolean[][] dp = new boolean[len][len];for (int j = 0; j < len; j++) {for (int i = 0; i <= j; i++) {//当两端字母一样时,才可以两端收缩进一步判断if (s.charAt(i) == s.charAt(j)) {//i++,j--,即两端收缩之后i,j指针指向同一个字符或者i超过j了,必然是一个回文串if (j - i < 3) {dp[i][j] = true;} else {//否则通过收缩之后的字串判断dp[i][j] = dp[i + 1][j - 1];}} else {//两端字符不一样,不是回文串dp[i][j] = false;}}}//遍历每一个字串,统计回文串个数for (int i = 0; i < len; i++) {for (int j = 0; j < len; j++) {if (dp[i][j]) ans++;}}return ans;}
}
解法二:双指针
class Solution {public int countSubstrings(String s) {int len, ans = 0;if (s == null || (len = s.length()) < 1) return 0;//总共有2 * len - 1个中心点for (int i = 0; i < 2 * len - 1; i++) {//通过遍历每个回文中心,向两边扩散,并判断是否回文字串//有两种情况,left == right,right = left + 1,这两种回文中心是不一样的int left = i / 2, right = left + i % 2;while (left >= 0 && right < len && s.charAt(left) == s.charAt(right)) {//如果当前是一个回文串,则记录数量ans++;left--;right++;}}return ans;}
}
题目二:最长回文子序列
力扣题目链接
题目描述:
给你一个字符串 s
,找出其中最长的回文子序列,并返回该序列的长度。
子序列定义为:不改变剩余字符顺序的情况下,删除某些字符或者不删除任何字符形成的一个序列。
思路分析:代码随想录
- 确定dp数组(dp table)以及下标的含义:dp[i][j]:字符串s在[i, j]范围内最长的回文子序列的长度为dp[i][j]。
- 确定递推公式:dp[i][j] = max(dp[i + 1][j], dp[i][j - 1])
- dp数组如何初始化:dp[i][j]初始为0
- 确定遍历顺序:从下到上遍历
- 举例推导dp数组
解法:
class Solution {public int longestPalindromeSubseq(String s) {int len = s.length();int[][] dp = new int[len + 1][len + 1];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;} else {dp[i][j] = Math.max(dp[i + 1][j], Math.max(dp[i][j], dp[i][j - 1]));}}}return dp[0][len - 1];}
}
代码随想录训练营day57相关推荐
- 【代码随想录训练营】Day43-动态规划
代码随想录训练营 Day43 今日任务 1049.最后一块石头的重量Ⅱ 494.目标和 474.一和零 语言:Java 1049. 最后一块石头的重量Ⅱ 链接:https://leetcode.cn/ ...
- 代码随想录训练营day8
目录 题目一:反转字符串 解法一:数值交换 解法二:位运算 题目二:反转字符串|| 题目三:替换空格 解法一:双指针 解法二:使用额外空间 题目四:翻转字符串里的单词 解法一: 解法二:纯属娱乐 题目 ...
- 【代码随想录训练营】【Day14】第六章|二叉树|理论基础|递归遍历|迭代遍历|统一迭代
理论基础 二叉树的定义形式有:节点指针和数组 在数组中,父节点的下标为i,那么其左孩子的下标即i*2+1,右孩子的下标即为i*2+2 二叉树的常见遍历形式有:前序遍历.后序遍历.中序遍历和层序遍历 前 ...
- 代码随想录训练营day56
题目一:两个字符串的删除操作 力扣题目链接 题目描述: 给定两个单词 word1 和 word2 ,返回使得 word1 和 word2 相同所需的最小步数. 每步 可以删除任意一个字符串中的一个字 ...
- 代码随想录训练营day53
题目一:最长公共子序列 力扣题目链接 题目描述: 给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度.如果不存在 公共子序列 ,返回 0 . 一个字符串的 子序列 ...
- 代码随想录训练营day55
题目一:判断子序列 力扣题目链接 题目描述: 给定字符串 s 和 t ,判断 s 是否为 t 的子序列. 字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩余字符相对位置形成的新字符 ...
- 代码随想录训练营day52
题目一:最长上升子序列 力扣题目链接 题目描述: 给你一个整数数组 nums ,找到其中最长严格递增子序列的长度. 子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序. ...
- 代码随想录训练营day48
题目一:打家劫舍 力扣题目链接 题目描述: 你是一个专业的小偷,计划偷窃沿街的房屋.每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上 ...
- 代码随想录训练营day51
题目一:最佳买卖股票时机含冷冻期 力扣题目链接 题目描述: 给定一个整数数组prices,其中第 prices[i] 表示第 i 天的股票价格 . 设计一个算法计算出最大利润.在满足以下约束条件下 ...
最新文章
- C#中方法的参数的四种类型(转)
- 内联汇编 - 从头开始
- 终于收到微软的衬衫了!!!
- 全球及中国农业保险市场营销状况与运营价值分析报告2022版
- 我的世界服务器无限装备指令2020,我的世界区域保护指令_我的世界区域保护指令除了自己手机版刷屏2020_攻略...
- html5常用插件大全,前端常用插件utils汇总
- JMS之企业消息传送
- python字符串相加_Python实用技法第33篇:字符串连接及合并
- 【测试】接口测试介绍
- C#基础16:事件与观察者模式
- python 直播源地址_斗鱼直播间真实rtmp地址获取(含工具类下载)
- yandex定位插件
- 安装Axure RP Extension for Chrome插件的简单方法
- Android 判断邮箱格式是否正确
- 人流量统计管理平台汇总显示方案_实现在场人数管控
- SystemUI之通知图标控制
- Plant Com:定量检测宿主微生物组的HA-QAP技术
- 麒麟子Cocos Creator 3D研究笔记五:模型骨骼动画查看器
- What is hosts?
- Linux根目录文件系统变为Read Only解决方案
热门文章
- wps2007版本如何生成目录的功能预览
- java websphere_将Java Web 应用部署至 WebSphere 7
- java Swing局域网聊天软件+ 情侣电脑钢琴
- 前进的动力来自有明确的目标
- [培训-无线通信基础-7]:信道均衡器(信道估计、信道均衡)
- 建站必备--素材网站大收集
- C#开源: 全局钩子+正则表达式=后台自动获取扫描枪数据
- win2008 R2解决安装网站安全狗提示HTTP 错误 500.21介绍
- scp 命令详解 ------ 远程复制
- html/javascript实现简单的上传