Leetcode之动态规划(DP)专题-647. 回文子串(Palindromic Substrings)



给定一个字符串,你的任务是计算这个字符串中有多少个回文子串。

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

示例 1:

输入: "abc"
输出: 3
解释: 三个回文子串: "a", "b", "c".

示例 2:

输入: "aaa"
输出: 6
说明: 6个回文子串: "a", "a", "a", "aa", "aa", "aaa".

注意:

  1. 输入的字符串长度不会超过1000。


dp:

定义:dp[i][j]表示在从i开始到j结束这段字符串里,如果是回文串,则dp[i][j]=1,不是则dp[i][j]=0;

状态转移方程:

if((s.charAt(i)==s.charAt(j)) && ((j-i<=2) || dp[i+1][j-1]==1)){
  dp[i][j] = 1;
}

举例解释:

"aba"

i=2 j=2    "a" 长度为1,是回文字符串。

i=1 j=1    "b" 长度为1,是回文字符串

i=1 j=2    "ab" 长度为2,但左不等于右,不是

i=0 j=0    "a" 长度为1,是回文字符串

i=0 j=1    "ab" 长度为2,且左不等于右,不是

i=0 j=2    "aba" 长度为3,且左等于右,是

        (只要长度为3,且左等于右,不管中间是什么,都是回文字符串)

再举一种情况  "abba"

i=0 j=3 截取后为"abba" 左等于右,但长度大于3,接着判断dp[i+1][j-1]是不是1,即判断dp[1][2],即字符串"bb"是不是回文串。

class Solution {
    public int countSubstrings(String s) {
        int res = 0;
        int n = s.length();
        int[][] dp = new int[n][n];
        for (int i = n-1; i >= 0; i--) {
            for (int j = i; j < n; j++) {
                if((s.charAt(i)==s.charAt(j)) && ((j-i<=2) || dp[i+1][j-1]==1)){
                    dp[i][j] = 1;
                    res++;
                }
            }
        }
        return res;
    }
}

原文地址:https://www.cnblogs.com/qinyuguan/p/11495149.html

时间: 2024-10-27 16:42:21

Leetcode之动态规划(DP)专题-647. 回文子串(Palindromic Substrings)的相关文章

LeetCode 647. 回文子串(Palindromic Substrings)

647. 回文子串 647. Palindromic Substrings 题目描述 给定一个字符串,你的任务是计算这个字符串中有多少个回文子串. 具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被计为是不同的子串. LeetCode647. Palindromic Substrings中等 示例 1: 输入: "abc" 输出: 3 解释: 3 个回文子串: "a", "b", "c". 示例 2: 输入: &

[Swift]LeetCode647. 回文子串 | Palindromic Substrings

Given a string, your task is to count how many palindromic substrings in this string. The substrings with different start indexes or end indexes are counted as different substrings even they consist of same characters. Example 1: Input: "abc" Ou

[LeetCode] 647. 回文子串 ☆☆☆(最长子串、动态规划、中心扩展算法)

描述 给定一个字符串,你的任务是计算这个字符串中有多少个回文子串. 具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被计为是不同的子串. 示例 1: 输入: "abc"输出: 3解释: 三个回文子串: "a", "b", "c".示例 2: 输入: "aaa"输出: 6说明: 6个回文子串: "a", "a", "a", "

[LeetCode]647. 回文子串(DP)

题目 给定一个字符串,你的任务是计算这个字符串中有多少个回文子串. 具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被计为是不同的子串. 示例 1: 输入: "abc" 输出: 3 解释: 三个回文子串: "a", "b", "c". 示例 2: 输入: "aaa" 输出: 6 说明: 6个回文子串: "a", "a", "a", &

LeetCode 第5题 最长回文子串

/* 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 示例 1: 输入: "babad" 输出: "bab" 注意: "aba" 也是一个有效答案. 示例 2: 输入: "cbbd" 输出: "bb" */ /*思路:动态规划 ,时间复杂度为O(n ^2) . boolean: dp[i][j] = {s[i-1] = s[j-1] && ( sij

Leetcode(5)最长回文子串

Leetcode(4)寻找两个有序数组的中位数 [题目表述]: 给定一个字符串 s,找到 s 中 最长 的回文子串.你可以假设 s 的最大长度为 1000.' 第一种方法:未完成:利用回文子串的特点 一开始我的思路如下:回文子串的特点是首尾字母相同,所以我对每一个字母都找到位于它后面的相同字母,利用切片判断这一段是否为回文子串(str[i:j]==str[i:j][::-1]).时间复杂度很高,主要是因为str.find操作非常耗时. class Solution(object): def lo

LeetCode之“字符串”:最长回文子串

题目要求: 给出一个字符串(假设长度最长为1000),求出它的最长回文子串,你可以假定只有一个满足条件的最长回文串.例如,给出字符串 "abcdzdcab",它的最长回文子串为 "cdzdc". 解答: 这个题目的一个简单的解法就是对字符串中的每一个字符,同时向其两边延展,以找到最长回文子串.这种方法是可以的,但要处理回文子串长度为奇数和偶数的两种情况是比较麻烦的.如下图的几个字符串: “a” "aa" "aaa" "

LeetCode刷题-005最长回文子串

给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为1000.示例 1:输入: "babad"输出: "bab"注意: "aba"也是一个有效答案.示例 2:输入: "cbbd"输出: "bb" 1 string longestPalindrome(string s) 2 { 3 4 string str = "$#"; 5 for(int i = 0; i &l

动态规划求字符串的回文子串

int size = s.size(); vector<vector<bool>> palindrome(size, vector<bool>(size, true)); for (int i = size - 1; i >= 0; i--) { for (int j = i; j < size; j++) { palindrome[i][j] = s[i] == s[j] && (j - i <= 2 || palindrome[i