从零开始的CPP(23)动态规划解决最长回文串

leetcode5

给你一个字符串 s,找到 s 中最长的

回文串

示例 1:

复制代码
输入:s = "babad"
输出:"bab"
解释:"aba" 同样是符合题意的答案。

最开始我是将回文串都存入map。使用substr进行切割,i为起始,j-i+1是步长

cpp 复制代码
string longestPalindrome(string s) {
    if (s.length() <= 1) {
        return s;
    }
    map<int,string> resultmap;
    string temp;
    for (int i = 0; i < s.length() - 1; i++) {
        for (int j = i; j < s.length(); j++) {               
            //cout << "temp:" << temp << endl;
            string s1 = s.substr(i, j-i+1);
            temp = s1;
            reverse(temp.begin(), temp.end());
            //cout << "s1:" << s1 << endl;
            if (temp == s1) {
                resultmap[i] = s1;
                //cout << "s1:" << s1 << endl;
            }
            
        }
    }
    int length = 0;
    int index = 0;
    for (int i = 0; i < resultmap.size(); i++) {
        if (resultmap[i].length() > length) {
            length = resultmap[i].length();
            index = i;
        }
    }
    return resultmap[index];
}

优化了一下,还是时间复杂度高

cpp 复制代码
string longestPalindrome(string s) {
    if (s.length() <= 1) {
        return s;
    }
    //map<int,string> resultmap;
    string temp;
    int max = 0;
    string maxstr;
    for (int i = 0; i < s.length() - 1; i++) {
        for (int j = i; j < s.length(); j++) {                             
            string s1 = s.substr(i, j - i + 1);
            temp = s1;
            if (s1.length() > max){
               reverse(temp.begin(), temp.end());
               //cout << "s1:" << s1 << endl;
               //cout << "temp:" << temp << endl;
               if (temp == s1) {
                   maxstr = s1;
                   max = s1.length();
                   //cout << "s1:" << s1 << endl;
               }
            }               
        }
    }
    
    return maxstr;
}

最终还是用动态规划的方式解决。动态规划的核心思想把已经发生过的情况储存起来,需要时直接调用,也就是空间换时间。

dp存储了某一段字符串是否是回文串,dp[i][j]的值如果为true,表示字符串s中从下标i到下标j的子串是一个回文串;如果为false,则不是回文串。

动态规划需要递推,所以也需要初始化,这里需要初始化单个字符串与连续字符串的情况,之后递推。

cpp 复制代码
string longestPalindrome(string s) {
    int n = s.length();
    if (n <= 1) {
        return s;
    }
    vector <vector<bool>> dp(n, vector<bool>(n, false));
    for (int i = 0; i < s.length(); i++) {
        dp[i][i] = true;
    }
    for (int i = 0; i < s.length()-1; i++) {
        if (s[i]==s[i+1])
        {
            dp[i][i+1] = true;
            dp[i+1][i] = true;
        }
    }
    int index=0;
    int maxlen=0;
    for (int len = 1; len < s.length(); len++) {
        for (int j = 0; j + len < s.length(); j++) {
            //cout << s[j] << endl << s[j + len]<<endl;
            if (s[j] == s[j + len] && dp[j + 1][j + len - 1]==true) {
                dp[j][j + len] = true;
                dp[j+len][j] = true;
                index = j;
                maxlen = len;
                cout << "找到回文" << ":";
                cout << index << "," << maxlen;
            }
        }
    }
    string res = s.substr(index, maxlen+1);
    return res;
}
相关推荐
Flobby52938 分钟前
Go 语言中的结构体、切片与映射:构建高效数据模型的基石
开发语言·后端·golang
lsx2024061 小时前
Vue.js 响应接口:深度解析与实践指南
开发语言
froginwe111 小时前
Vue.js 样式绑定
开发语言
草莓熊Lotso2 小时前
【洛谷题单】--分支结构(三)
c语言·c++·刷题·洛谷
GetcharZp3 小时前
C++日志库新纪元:为什么说spdlog是现代C++开发者必备神器?
c++·后端
Algebraaaaa3 小时前
为什么C++主函数 main 要写成 int 返回值 | main(int argc, char* argv[]) 这种写法是什么意思?
开发语言·c++
java1234_小锋4 小时前
一周学会Matplotlib3 Python 数据可视化-绘制饼状图(Pie)
开发语言·python·信息可视化
悟能不能悟5 小时前
能刷java题的网站
java·开发语言
IT古董5 小时前
【第四章:大模型(LLM)】05.LLM实战: 实现GPT2-(6)贪婪编码,temperature及tok原理及实现
android·开发语言·kotlin
程序员陆通6 小时前
Java高并发场景下的缓存穿透问题定位与解决方案
java·开发语言·缓存