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();
    }
};
相关推荐
南宫萧幕8 小时前
Python与Simulink联合仿真:基于DQN的HEV能量管理策略建模与全链路排雷实战
开发语言·人工智能·python·算法·机器学习·matlab·控制
apollowing9 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(优)
算法·启发式算法·web app
Chat_zhanggong3459 小时前
主推NT98336BG作用有哪些?
嵌入式硬件·算法
Run_Teenage10 小时前
算法:线段树
算法
Westward-sun.10 小时前
YOLOv2算法全方位解析:从BatchNorm到聚类先验框的九大改进
算法·yolo·聚类
扶苏xw10 小时前
【离散化算法】
算法
码之气三段.10 小时前
Codeforces Round 1095 (Div. 2) 补题
算法
6Hzlia10 小时前
【Hot 100 刷题计划】 LeetCode 189. 轮转数组 | C++ 三次反转经典魔法 (O(1) 空间)
c++·算法·leetcode
wuweijianlove10 小时前
算法可扩展性建模与渐进性能分析的技术7
算法
shehuiyuelaiyuehao10 小时前
算法14,滑动窗口,找到字符串中所有字母异位词
算法