题解 | #最长回文子序列#

最长回文子序列

https://www.nowcoder.com/practice/82297b13eebe4a0981dbfa53dfb181fa

import java.util.Scanner;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        String s = in.next();
        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 (i == j) {
                    dp[i][j] = 1;
                } else {
                    if (s.charAt(i) == s.charAt(j)) {
                        if (j - i == 1) {
                            dp[i][j] = 2;
                        } else {
                            dp[i][j] = dp[i + 1][j - 1] + 2;
                        }
                    } else {
                        
                        dp[i][j]=Math.max(dp[i][j],dp[i+1][j]);
                        dp[i][j]=Math.max(dp[i][j],dp[i][j-1]);
                    }
                }
            }
        }
        System.out.print(dp[0][n-1]);
    }
}

动态规划思路,dp数组表示下标i到下标j之间的字符串中最长的回文子序列长度。

可将求回文子序列的过程分为以下四种情况:

第一种: i==j 即单个字符,必为回文所以此时dp[i][j]=1;

第二种:j-i==1即恰好为长度为2的字符串且第i个字符是否与第j个字符相等,相等则dp[i][j]=2;

第三种:第j个字符恰与第i个字符相等,且j-i>1,此时最长回文子序列的长度为 从i+1到 j-1的字符串中最长回文子序列的长度再加2,即dp[i][j]=d[i+1][j-1]+2;

第四种: 第j个字符与第i个字符不相等,则此时dp[i][j] = Max(dp[i+1]dp[j],dp[i][j-1])

全部评论

相关推荐

02-05 08:49
已编辑
武汉大学 Web前端
野猪不是猪🐗:36k和36k之间亦有差距,ms的36k和pdd的36k不是一个概念
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务