Appearance
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];
};