Coding Caprice - dynamic programming13

647. 回文子串

cpp 复制代码
class Solution {
public:
    int countSubstrings(string s) {
        int s_len = s.size();
        vector<int> dp{0};
        int out(1);
        for(int i=1; i<s_len; ++i){
            out++;
            vector<int> dq{i};
            if(s[i]==s[i-1]){
                dq.push_back(i-1);
                out++;
            }
            for(int j:dp){
                if(j>0&&s[j-1]==s[i]){
                    dq.push_back(j-1);
                    out++;
                }
            }
            swap(dp, dq);
         }
         return out;
    }
};
  • 搞笑了

516. 最长回文子序列

cpp 复制代码
class Solution {
public:
    int longestPalindromeSubseq(string s) {
        if(s.size()==1){return 1;}
        if(s.size()==2){return s[0]==s[1]?2: 1;}
        int len = s.size();
        vector<vector<int>> dp(len, vector<int> (len, 0));
        for(int i=0; i<len; ++i){
            dp[i][i] = 1;
            if(i+1>=len){break;}
            if(s[i] == s[i+1]){
                dp[i][i+1] = 2;
            }else{
                dp[i][i+1] = 1;
            }
        }
        for(int j=2; j<len; ++j){
            for(int i=0; i<len; ++i){
                if(i+j>=len){break;}
                if(s[i]==s[i+j]){
                    dp[i][i+j] = dp[i+1][i+j-1] + 2;
                }else{
                    dp[i][i+j] = max(dp[i+1][i+j], dp[i][i+j-1]);
                }
            }
        }
        return dp[0].back();
    }
};
相关推荐
qq7422349842 分钟前
APS系统与OR-Tools完全指南:智能排产与优化算法实战解析
人工智能·算法·工业·aps·排程
A尘埃29 分钟前
超市购物篮关联分析与货架优化(Apriori算法)
算法
.小墨迹35 分钟前
apollo学习之借道超车的速度规划
linux·c++·学习·算法·ubuntu
不穿格子的程序员1 小时前
从零开始刷算法——贪心篇1:跳跃游戏1 + 跳跃游戏2
算法·游戏·贪心
大江东去浪淘尽千古风流人物1 小时前
【SLAM新范式】几何主导=》几何+学习+语义+高效表示的融合
深度学习·算法·slam
铉铉这波能秀1 小时前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list
重生之我是Java开发战士1 小时前
【优选算法】模拟算法:替换所有的问号,提莫攻击,N字形变换,外观数列,数青蛙
算法
仟濹1 小时前
算法打卡 day1 (2026-02-06 周四) | 算法: DFS | 1_卡码网98 可达路径 | 2_力扣797_所有可能的路径
算法·leetcode·深度优先
yang)1 小时前
欠采样时的相位倒置问题
算法
历程里程碑1 小时前
Linux20 : IO
linux·c语言·开发语言·数据结构·c++·算法