Leetcode Hot100 第21题 647.回文子串

cpp 复制代码
class Solution {
public:
    int countSubstrings(string s) {
        int N = s.size();
        vector<vector<bool>> dp(N,vector<bool>(N,false));
        // dp[i][j] = dp[i+1][j-1]
        int result = 0;
        for(int i=N-1;i>=0;i--){
            for(int j=i;j<N;j++){
                if(s[i]==s[j]){
                    if(j-i==0 || j-i==1) dp[i][j]=true;
                    else dp[i][j] = dp[i+1][j-1];
                }
                if(dp[i][j]) result++;
            }
        }
        return result;
    }
};
相关推荐
Swift社区5 小时前
LeetCode 465 最优账单平衡
算法·leetcode·职场和发展
聆风吟º5 小时前
【数据结构手札】空间复杂度详解:概念 | 习题
java·数据结构·算法
weixin_445054725 小时前
力扣热题51
c++·python·算法·leetcode
地平线开发者5 小时前
linux 常见稳定性问题分析方法
算法·自动驾驶
s砚山s5 小时前
代码随想录刷题——二叉树篇(九)
算法
地平线开发者6 小时前
大模型常见量化方法简介
算法·自动驾驶
smj2302_796826528 小时前
解决leetcode第3801题合并有序列表的最小成本
数据结构·python·算法·leetcode
栗少9 小时前
英语自学手册:系统化进阶指南基于《英语自学手册》的方法论与行动路径
人工智能·算法
Xの哲學9 小时前
深入解析 Linux systemd: 现代初始化系统的设计与实现
linux·服务器·网络·算法·边缘计算
sinat_255487819 小时前
InputStream/OutputStream小讲堂
java·数据结构·算法