【代码随想录训练营】Day57-动态规划
admin
2024-03-23 20:07:49

代码随想录训练营 Day57

今日任务

647.回文子串
516.最长回文子序列
动态规划总结
语言:Java

647. 回文子串

链接:https://leetcode.cn/problems/palindromic-substrings/

class Solution {public int countSubstrings(String s) {int[][] dp = new int[s.length()][s.length()];//dp[i][j]: 从i~j的子串是否为回文子串int res = 0;for(int i = s.length() - 1; i >= 0; i--){for(int j = i; j < s.length(); j++){if(s.charAt(i) == s.charAt(j)){if(i == j){dp[i][j] = 1;}else if(Math.abs(j - i) == 1){dp[i][j] = 1;}else if(j - i > 1){dp[i][j] = dp[i + 1][j - 1];}}res += dp[i][j];}}return res;}
};/*a   b   b   a   ca   1   0   0   1   0b       1   1   0   0b           1   0   0a               1   0c                   1*/

516. 最长回文子序列

链接:https://leetcode.cn/problems/longest-palindromic-subsequence/
代码随想录

class Solution {public int longestPalindromeSubseq(String s) {int[][] dp = new int[s.length()][s.length()];//i~j位的最长子串长度for(int i = 0; i < s.length(); i++){dp[i][i] = 1;}for(int i = s.length() - 1; i >= 0; i--){for(int j = i + 1; j < s.length(); j++){//如果相等,就说明i位和j位都可以加入到当前最长回文子序列中if(s.charAt(i) == s.charAt(j)){dp[i][j] = dp[i + 1][j - 1] + 2;}//如果不相等,就寻找加入i位或j位后最长回文子序列更长的else{dp[i][j] = Math.max(dp[i + 1][j], dp[i][j - 1]);}}}return dp[0][s.length() - 1];}
}
/*b   b   b   a   bb   1   2   3   3   4b       1   2   2   3b           1   1   2a               1   1b                   1*/
/*c   b   b   dc   1   1   2   2b       1   2   2b           1   1d               1*/

相关内容

热门资讯

刘集黄酒,正在改写南阳黄酒产业... 刘集黄酒,正在改写南阳黄酒产业新格局 长期以来,南阳黄酒坐拥千年酿造文脉、成熟产区根基,却长期深陷发...
原创 国... 标题:国宴白菜清汤寡水?实则经历了无数道工序,每一道都很严谨 在探讨国宴上的白菜清汤时,我们可能会...
禾利生湿面批发的湿面,其营养成... 在当今的湿面市场中,禾利生湿面批发的湿面凭借其独特的优势和特点,吸引了众多消费者的关注。接下来,我们...
原创 5... 前段时间,社交平台一条吐槽帖直接刷屏,无数网友纷纷抱团感慨,现如今连麻辣烫都不敢随便吃了。 事情起因...