题解 | #最长回文子序列#
最长回文子序列
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])

