代码随想录——回文子串(Leetcode 647)

题目链接
在这里插入图片描述

我的题解(双指针)

思路:
当然,以下是对您提供的代码的解释:

class Solution {public int countSubstrings(String s) {// 初始化回文子字符串的数量int count = 0;// 遍历字符串的每个字符,使用索引 ifor(int i = 0; i < s.length(); i++){// 初始化两个指针 left 和 right,都指向当前位置 i// 用于查找以 i 为中心的奇数长度回文子字符串int left = i, right = i;// 当 left 和 right 都在字符串范围内,并且 s[left] 等于 s[right] 时// 继续查找while (left >= 0 && right < s.length() && s.charAt(left) == s.charAt(right)) {// 如果找到了一个回文子字符串,增加计数count++;// 移动 left 指针向左,right 指针向右,继续查找更长的回文子字符串left--;right++;}// 重新初始化 left 指针到 i,right 指针到 i+1// 用于查找以 i 和 i+1 为中心的偶数长度回文子字符串left = i;right = i + 1;// 同样的逻辑,当 left 和 right 都在字符串范围内,并且 s[left] 等于 s[right] 时// 继续查找while (left >= 0 && right < s.length() && s.charAt(left) == s.charAt(right)) {// 如果找到了一个回文子字符串,增加计数count++;// 移动 left 指针向左,right 指针向右,继续查找更长的回文子字符串left--;right++;}}// 返回总共找到的回文子字符串的数量return count;}
}

详细解释:

  1. int left = i, right = i; 初始化两个指针 leftright,都指向当前位置 i这是为了查找以 i 为中心的奇数长度回文子字符串
  2. 第一个 while 循环:while (left >= 0 && right < s.length() && s.charAt(left) == s.charAt(right))。这个循环用于检查当前位置为中心的字符是否可以扩展成回文。它检查以下条件:
    • left 指针是否仍然在字符串范围内。
    • right 指针是否仍然在字符串范围内。
    • 当前 leftright 指向的字符是否相同。
      如果以上条件都满足,那么 count++ 增加计数,然后 left--right++ 来检查下一个可能的回文子字符串。
  3. left = i; right = i + 1; 重新初始化 leftright 指针,这次是为了查找以 ii+1 为中心的偶数长度回文子字符串
  4. 第二个 while 循环与第一个相同,但这次检查的是偶数长度的回文子字符串。
class Solution {public int countSubstrings(String s) {int count = 0;for(int i = 0; i < s.length(); i++){// 奇数int left = i, right = i;while (left >= 0 && right < s.length() && s.charAt(left) == s.charAt(right)) {count++;left--;right++;}// 偶数left = i;right = i + 1;while (left >= 0 && right < s.length() && s.charAt(left) == s.charAt(right)) {count++;left--;right++;}}return count;}
}

在字符串中查找回文子字符串时,区分奇数长度和偶数长度是因为它们的中心点不同:

  1. 奇数长度回文子字符串
    • 奇数长度的回文子字符串有一个中心字符。例如,在字符串 “abcba” 中,‘c’ 是中心字符,整个字符串是一个奇数长度的回文子字符串。
    • 对于每个字符 s[i],我们可以将其视为一个潜在的中心,然后尝试向左和向右扩展,以查看是否存在一个以 s[i] 为中心的回文子字符串。
  2. 偶数长度回文子字符串
    • 偶数长度的回文子字符串没有中心字符,而是有两个中心点。例如,在字符串 “abba” 中,‘b’ 和另一个 ‘b’ 是中心点,整个字符串是一个偶数长度的回文子字符串。
    • 对于每个字符 s[i],我们还可以检查 s[i]s[i+1] 是否可以形成一对中心点,然后同样尝试向左和向右扩展,以查看是否存在一个以 s[i]s[i+1] 为中心的回文子字符串。
      因此,必须分别考虑这两种情况,因为它们的扩展方式不同:
  • 对于奇数长度,我们从单个字符开始,向两侧扩展。
  • 对于偶数长度,我们从两个连续字符开始,向两侧扩展。

优秀题解(动态规划)

思想:
找到一种递归关系,判断一个子字符串(字符串下标范围[i,j])是否回文,依赖于,子字符串(下标范围[i + 1, j - 1]))是否是回文。

    1. 确定dp数组(dp table)以及下标的含义
      dp[i][j]:表示区间范围[i,j] (注意是左闭右闭)的子串是否是回文子串,如果是dp[i][j]为true,否则为false。
    1. 确定递推公式
    • s[i] = s[j]
      - 下标i = j,例如a,是回文子串dp[i][j] = true
      - 下标j - i = 1,例如aa,是回文子串dp[i][j] = true
      - 下标j - i > 1,例如cabac,此时s[i]与s[j]已经相同了,我们看i到j区间是不是回文子串就看aba是不是回文就可以了,那么aba的区间就是 i+1 与 j-1区间,这个区间是不是回文就看dp[i + 1][j - 1]是否为true
    • s[i] != s[j]
      - 下标i ≠ j,dp[i][j] = false
    1. dp数组如何初始化
      dp[i][j]初始化为false。
    1. 确定遍历顺序
      情况三是dp[i + 1][j - 1],所以一定要从下到上,从左到右遍历,这样保证dp[i + 1][j - 1]都是经过计算的。
class Solution {public int countSubstrings(String s) {int count = 0;boolean[][] dp = new boolean[s.length()][s.length()];for(int i = s.length() - 1; i >= 0; i--){for(int j = i; j < s.length(); j++){if(s.charAt(i) == s.charAt(j)){if(j - i <= 1){dp[i][j] = true;count++;}else{dp[i][j] = dp[i + 1][j - 1];if(dp[i][j] == true){count++;}}}else{dp[i][j] = false;}}}return count;}
}

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

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

相关文章

综合评价 | 基于熵权-变异系数-博弈组合法的综合评价模型(Matlab)

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 根据信息熵的定义&#xff0c;对于某项指标&#xff0c;可以用熵值来判断某个指标的离散程度&#xff0c;其信息熵值越小&#xff0c;指标的离散程度越大&#xff0c; 该指标对综合评价的影响&#xff08;即权重&…

基于鸿道Intewell操作系统的运动控制系统方案

随着工业控制行业的蓬勃发展&#xff0c;操作系统实时与非实时业务的深度融合应用需求日益增长&#xff0c;特别是在Windows或Linux平台上处理机器视觉等复杂场景时&#xff0c;传统实时操作系统&#xff08;RTOS&#xff09;面临显著挑战。这些挑战主要体现在两方面&#xff1…

欢迎体验 tuya open-sdk for arduino

我们很高兴地宣布 tuya open-sdk 1.0.0 发布&#xff0c;tuya open-sdk 包括&#xff1a;https://github.com/tuya/tuya-open-sdk-for-device 和 https://github.com/tuya/arduino-tuyaopen 等多个系列&#xff0c;1.1.0 版本正在紧张开发中&#xff0c;敬请期待&#xff01; …

视频监控系统布局策略:EasyCVR视频汇聚平台构建高效、全面的安全防线

随着科技的飞速发展&#xff0c;视频监控系统已成为现代社会安全防范的重要组成部分&#xff0c;广泛应用于公共场所、企业园区、住宅小区等各个领域。一个科学合理的视频监控系统布局与选型策略&#xff0c;不仅能够显著提升安全监控的效率和效果&#xff0c;还能在关键时刻提…

DNN学习平台(GoogleNet、SSD、FastRCNN、Yolov3)

DNN学习平台&#xff08;GoogleNet、SSD、FastRCNN、Yolov3&#xff09; 前言相关介绍1&#xff0c;登录界面&#xff1a;2&#xff0c;主界面&#xff1a;3&#xff0c;部分功能演示如下&#xff08;1&#xff09;识别网络图片&#xff08;2&#xff09;GoogleNet分类&#xf…

揭秘Vue 2生命周期:从创建到毁灭的全面指南

Vue.js作为当前最受欢迎的前端框架之一&#xff0c;其生命周期方法是每个Vue开发者必须掌握的核心内容。下面将详细解释Vue2中的每个生命周期钩子的作用、概念和应用场景&#xff0c;并提供代码演示来进一步阐明其工作原理。以下是关于vue2中的生命周期每个参数的作用、概念、应…

海外网络加速方案:解决海外访问难题

随着全球化的浪潮不断推进&#xff0c;越来越多的人和企业开始涉足海外市场&#xff0c;寻求更广阔的资源与机遇。然而&#xff0c;在海外访问过程中&#xff0c;网络速度慢、连接不稳定等问题频繁出现&#xff0c;不仅影响了个人网络体验&#xff0c;更对企业的日常运营和国际…

【学术会议征稿】2024年第十届机械制造技术与工程材料国际学术会议(ICMTEM 2024)

2024年第十届机械制造技术与工程材料国际学术会议&#xff08;ICMTEM 2024&#xff09; 2024 10th International Forum on Manufacturing Technology and Engineering Materials 第十届机械制造技术与工程材料国际学术会议&#xff08;ICMTEM 2024&#xff09;将于2024年10月…

QT学习之计算器

网格布局初尝试&#xff0c;快速构建计算器 项目结构&#xff1a; wident.h拖动建立界面&#xff0c;20个button&#xff0c;一个lineedit 布局好后整体网格布局调整&#xff0c;依次给每个案件输入文本&#xff0c;并改objectname方便后期辨识 为了在lineedit显示数字&…

WPF性能优化之UI虚拟化

文章目录 前言一、VirtualizingStackPanel1.1 虚拟化功能介绍1、在Window中添加一个ListBox控件。2、在设计视图中用鼠标选中ListBox控件并右健依次单击“编辑其他模板”&#xff0d;“编辑项的布局模板”&#xff0d;“编辑副本”。3、查看生成的模板代码。 1.2 虚拟化参数介绍…

F12抓包04:(核心功能)Network接口抓包、定位缺陷

课程大纲 一、录制请求 ① tab导航选择“网络”&#xff08;Network&#xff09;&#xff0c;即可进入网络抓包界面&#xff0c;进入界面默认开启录制模式&#xff0c;显示浏览器当前标签页的请求列表。 ② 查看请求列表&#xff0c;包含了当前标签页执行的所有请求和下载的资…

分支管理

目录 创建分支 切换分支 合并分支 删除分支 合并冲突 创建分支 git branch [分支]指令 创建新的分⽀后&#xff0c;Git 新建了⼀个指针叫dev&#xff0c; * 表⽰当前 HEAD 指向的分⽀是 master 分⽀。另外&#xff0c;可以通过⽬录结构发现&#xff0c;新的 dev 分⽀…

保姆级教学:OC监听网络状态变化 Reachability监听网络变化 ios网络变化

本文主要讲解了,在oc开发中,怎么去使用代码进行网络监听,十分的通俗易懂。 首先,在xcode工程中导入SystemConfiguration框架。 然后导入Reachability.h文件。 Reachability文件 点击下载,也可以按照如下内容创建对应的文件。 Reachability.m //文件名Reachability.m …

多线程 | synchronized的简单使用

synchronized 关键字是 Java 中解决并发问题的一种常用方法&#xff0c;也是最简单的一种方法&#xff0c;其作用有三个: &#xff08;1&#xff09;互斥性&#xff1a;确保线程互斥的访问同步代码 &#xff08;2&#xff09;可见性&#xff1a;保证共享变量的修改能够及时可见…

探索Pyro4:Python中的远程对象通信艺术

文章目录 探索Pyro4&#xff1a;Python中的远程对象通信艺术背景&#xff1a;为何选择Pyro4&#xff1f;Pyro4是什么&#xff1f;如何安装Pyro4&#xff1f;简单的库函数使用方法场景应用示例常见Bug及解决方案总结 探索Pyro4&#xff1a;Python中的远程对象通信艺术 背景&…

C 语言指针与数组的深度解析

目录 ​编辑 一、引言 二、指针的基本概念 1.定义与声明 2.指针的运算 3.指针的作用 三、数组的基本概念 1.定义与声明 2.数组的初始化 3.数组的大小 四、指针与数组的关系 1.数组名作为指针 2.指针与数组的相互转换 3.指针与数组的参数传递 五、指针与数组的高…

深度学习(九)-图像形态操作

仿射变换 仿射变换是指图像可以通过一系列的几何变换来实现平移、旋转等多种操作。该变换能够保持图像的平直性和平行性。平直性是指图像经过仿射变换后&#xff0c;直线仍然是直线&#xff1b;平行性是指图像在完成仿射变换后&#xff0c;平行线仍然是平行线。 平移 镜像 旋转…

[已更新问题二三matlab+python]2024数学建模国赛高教社杯C题:农作物的种植策略 思路代码文章助攻手把手保姆级

发布于9.6 10:00 有问题后续会修正!! 问题一代码展示: 问题二代码结果展示: 问题三代码展示: https://docs.qq.com/doc/DVVVlV0NmcnBDTlVJ问题一部分代码分享: #!/usr/bin/env python # coding: utf-8# In[15]:import pandas as pd# In[16]:# 读取Excel文件 file_path 附件2…

通义灵码助力高校开学第一课,“包”你满意,新学期加油!

通义灵码作为国内领先的 AI 编码工具&#xff0c;近年来在高校中得到了广泛应用和推广。它不仅帮助大学生更高效地学习编程、提高代码质量&#xff0c;还激发了他们的创新思维&#xff0c;并为未来的职业生涯做好了准备。 通义灵码是什么&#xff1f; 通义灵码是一款基于通义…

数据分析新星,DuckDB与Pandas处理大数据速度对比

大家好&#xff0c;Pandas库众所周知&#xff0c;适合数据分析新手入门&#xff0c;但在大数据面前却显得处理缓慢。相比之下&#xff0c;开源的DuckDB以其卓越的列式存储性能&#xff0c;在大数据处理上速度惊人&#xff0c;速度远超Pandas。而且&#xff0c;DuckDB配备了Pyth…