Skip to content

516.最长回文子序列

题解

js
/**
 * @param {string} s
 * @return {number}
 */
var longestPalindromeSubseq = function (s) {
  const dp = Array.from(Array(s.length), () => Array(s.length).fill(0));
  for (let i = 0; i < s.length; i++) dp[i][i] = 1;
  let res = 1;
  // 左指针
  for (let i = s.length - 1; i >= 0; i--) {
    // 右指针
    // 这里之所以从i + 1开始,是因为 i === j的时候 必定是回文
    for (let j = i + 1; j < s.length; j++) {
      if (s[i] === s[j]) {
        dp[i][j] = dp[i + 1][j - 1] + 2;
      } else {
        dp[i][j] = Math.max(dp[i + 1][j], dp[i][j - 1]);
      }
    }
  }
  return dp[0][s.length - 1];
};
/**
 * @param {string} s
 * @return {number}
 */
var longestPalindromeSubseq = function (s) {
  const dp = Array.from(Array(s.length), () => Array(s.length).fill(0));
  for (let i = 0; i < s.length; i++) dp[i][i] = 1;
  let res = 1;
  // 左指针
  for (let i = s.length - 1; i >= 0; i--) {
    // 右指针
    // 这里之所以从i + 1开始,是因为 i === j的时候 必定是回文
    for (let j = i + 1; j < s.length; j++) {
      if (s[i] === s[j]) {
        dp[i][j] = dp[i + 1][j - 1] + 2;
      } else {
        dp[i][j] = Math.max(dp[i + 1][j], dp[i][j - 1]);
      }
    }
  }
  return dp[0][s.length - 1];
};