每日一练:回文子串

LCR 020. 回文子串 - 力扣(LeetCode)

题目要求:

给定一个字符串 s ,请计算这个字符串中有多少个回文子字符串。

具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被视作不同的子串。

示例 1:

复制代码
输入:s = "abc"
输出:3
解释:三个回文子串: "a", "b", "c"

示例 2:

复制代码
输入:s = "aaa"
输出:6
解释:6个回文子串: "a", "a", "a", "aa", "aa", "aaa"

提示:

  • 1 <= s.length <= 1000
  • s 由小写英文字母组成

解法-1 动态规划 O(N^2):

这道题可以使用dp表保存所有子串状态:

创建一个二维dp表,dp[i][j]保存以s[j]为开头、s[i]为结尾的子串是否为回文,状态转移方程如下:

如果s[j] != s[i],则必不会是回文,dp[i][j] = false;

如果s[j] == s[i]:

(1)并且i==j,只有一个字母一定是回文;

(2)并且j == i-1,两个相同字母也一定是回文;

(3)并且j < i-1 && dp[i-1][j+1],它们中间有字符,且中间的子串也是回文,则一定是回文。

cpp 复制代码
class Solution {
public:
    int countSubstrings(string s) {
        int n = s.size();

        vector<vector<bool>> dp(n);
        for (int i = 0; i < n; i++)
            dp[i].resize(i + 1, true);

        int ret = 1;
        for (int i = 1; i < n; i++) {
            for (int j = 0; j <= i; j++) {
                if (s[i] != s[j])
                    dp[i][j] = false;
                else if (j < i - 1) // i、j中间有其他字符
                    dp[i][j] = dp[i - 1][j + 1];

                ret += dp[i][j] ? 1 : 0;
            }
        }

        return ret;
    }
};
相关推荐
freexyn几秒前
Matlab自学笔记五十一:(推荐)输入参数的数量和可变数量的输入
笔记·算法·matlab
陈大大陈3 分钟前
基于 C++ 的用户认证系统开发:从注册登录到Redis 缓存优化
java·linux·开发语言·数据结构·c++·算法·缓存
纪元A梦6 分钟前
华为OD机试真题——通过软盘拷贝文件(2025A卷:200分)Java/python/JavaScript/C++/C语言/GO六种最佳实现
java·javascript·c++·python·华为od·go·华为od机试题
数据分析螺丝钉21 分钟前
LeetCode 252 会议室 III(Meeting Rooms III)题解与模拟面试
算法·leetcode·职场和发展
小李独爱秋24 分钟前
动态哈希映射深度指南:从基础到高阶实现与优化
数据结构·算法·哈希算法
猫猫头有亿点炸33 分钟前
C语言斐波拉契数列2.0
c语言·开发语言·算法
刚入坑的新人编程41 分钟前
C++多态
开发语言·c++
写个博客1 小时前
代码随想录算法训练营第二十六天
算法
QUST-Learn3D1 小时前
高精度并行2D圆弧拟合(C++)
开发语言·c++
明月醉窗台1 小时前
Qt 入门 6 之布局管理
c语言·开发语言·c++·qt