647. 回文子串 - 力扣(LeetCode)

图示

代码

python 复制代码
# encoding = utf-8
# 开发者:Alen
# 开发时间: 15:08 
# "Stay hungry,stay foolish."


class Solution(object):
    def countSubstrings(self, s):
        """
        :type s: str
        :rtype: int
        """
        # 1. 预处理字符串,例如 "abc" 变成 "^#a#b#c#$"
        # 加入 ^ 和 $ 是为了防止越界处理,不需要写额外的边界判断
        t = "^#" + "#".join(s) + "#$"
        n = len(t)

        # p 数组记录以每个字符为中心的回文半径
        p = [0] * n
        center = right = 0
        count = 0

        for i in range(1, n - 1):
            # i_mirror 是 i 关于 center 的对称点
            i_mirror = 2 * center - i # center - i_mirror = i - center

            # 核心优化:如果 i 在 right 边界内,利用对称性快速初始化回文半径
            if right > i:
                p[i] = min(right - i, p[i_mirror])

            # 中心扩展(尝试扩大回文半径)
            while t[i + 1 + p[i]] == t[i - 1 - p[i]]:
                p[i] += 1

            # 如果扩展后的右边界超过了当前的 right,则更新中心和右边界
            if i + p[i] > right:
                center = i
                right = i + p[i]

            # 记录回文串数量
            # 原字符串中以该点为中心的回文串数量等于其半径除以 2(向上取整)
            # 由于 p[i] 记录的是加了 # 后的半径,(p[i] + 1) // 2 正好等于回文子串个数
            count += (p[i] + 1) // 2

        return count

结果

解题步骤:https://www.bilibili.com/video/BV1mV9TBNEf3/

相关推荐
知识浅谈5 小时前
DeepSeek V4 和 GPT-5.5 在同一天发布了??我也很懵,但对比完我悟了
算法
蒸汽求职5 小时前
跨越 CRUD 内卷:半导体产业链与算力基建下的软件工程新生态
人工智能·科技·面试·职场和发展·软件工程·制造
DeepModel5 小时前
通俗易懂讲透 Q-Learning:从零学会强化学习核心算法
人工智能·学习·算法·机器学习
田梓燊5 小时前
力扣:19.删除链表的倒数第 N 个结点
算法·leetcode·链表
简简单单做算法7 小时前
基于GA遗传优化双BP神经网络的时间序列预测算法matlab仿真
神经网络·算法·matlab·时间序列预测·双bp神经网络
guygg887 小时前
利用遗传算法解决列车优化运行问题的MATLAB实现
开发语言·算法·matlab
武藤一雄7 小时前
19个核心算法(C#版)
数据结构·windows·算法·c#·排序算法·.net·.netcore
sali-tec7 小时前
C# 基于OpenCv的视觉工作流-章52-交点查找
图像处理·人工智能·opencv·算法·计算机视觉
yu85939588 小时前
MATLAB连续线性化模型预测控制(SL-MPC)
算法·机器学习·matlab
ytttr8738 小时前
基于ACADO工具包的自主车道跟踪与避障MPC控制
算法