/*参考lc 用户 @a380922457 的解答,动态规划
*作者@v7fgg
*执行用时 :52 ms, 在所有 Java 提交中击败了29.52%的用户
*内存消耗 :50.2 MB, 在所有 Java 提交中击败了6.90%的用户
*2020年6月7日 21:58
*/
class Solution {
public int longestPalindromeSubseq(String s) {
int l=s.length();
//ans[a][b]表示s的第a到第b位的最大回文子串数
int[][] ans=new int[l][l];
for(int i=0;i<l;i++){
ans[i][i]=1;
}
for(int i=l-1;i>=0;i--){
for(int j=i+1;j<l;j++){
if(s.charAt(i)==s.charAt(j)){
ans[i][j]=ans[i+1][j-1]+2;
}
else{
ans[i][j]=Math.max(ans[i+1][j],ans[i][j-1]);
}
}
}
return ans[0][l-1];
}
}
//参考资料:https://leetcode-cn.com/problems/longest-palindromic-subsequence/solution/dong-tai-gui-hua-si-yao-su-by-a380922457-3
leetcode 516.最长回文子串
最新推荐文章于 2024-09-24 08:39:28 发布