[力扣题解]131. 分割回文串

题目:131. 分割回文串

思路

回溯法
切割问题:在某个地方画一个挡板,比如aab可以画成:a|aba|a|b,每个字母之间理论上都可画一个挡板;
抽象成当前n个字母,画一道挡板,挡板后面剩下的字母,再画一道挡板,所以可以用回溯法解决;
注意挡板位置在字母右侧,遍历时用i表示,比如i = 0,位置如下:a|abi = size,位置如下:aab|,此时已经遍历完毕;

代码

// 代码随想录说这其实是一道`hard`题目
// 自己写的哦!
class Solution {
public:
    vector<vector<string>> result;
    vector<string> path;

    bool compare(const string& s)
    {
        int i, j;
        int size = s.size();
        for(i = 0, j = size-1; i < j; i++, j--)
        {
            if(s[i] != s[j])
            {
                return false;
            }
        }
        return true;
    }

    void function(string s, int startindex)
    {
        int i, size;
        if(startindex == s.size())
        {
            result.push_back(path);
            return;
        }

        size = s.size();
        for(i = startindex; i < size; i++)
        {
            string temp = s.substr(startindex, i-startindex+1);
            // 是回文串
            if(compare(temp)) 
            {
                path.push_back(temp);
                function(s, i+1);
                path.pop_back();
            }
        }
    }

    vector<vector<string>> partition(string s) {
        result.clear();
        path.clear();
        function(s, 0);
        return result;
    }
};

判断是否回文串:双指针法
注意回溯处理当前子串是指区间[startindex, i]这部分,所以接下来调用递归应该是function(s, i+1);,从i+1开始;
获取子串用到函数substr(),用法如下:
str = s.substr(pos, len);
从位置pos开始的len个元素(包括pos);

难点(Carl总结)

  • 切割问题可以抽象成组合问题;
  • 如何模拟那些切割线;
  • 切割问题中递归如何终止;
  • 在递归循环中如何截取子串;
  • 如何判断回文;

剪枝

还可以用动态规划的思想,逻辑是这样:
对于字符串abcde来说,如果判断到中间段bcd不是回文串,那么整个abcde也必定不是回文串;

相关推荐

  1. [题解]131. 分割

    2024-05-09 22:12:05       13 阅读
  2. 131. 分割

    2024-05-09 22:12:05       31 阅读
  3. 分割131

    2024-05-09 22:12:05       12 阅读
  4. 131. 分割

    2024-05-09 22:12:05       10 阅读
  5. 每日OJ题_dp④_132. 分割 II

    2024-05-09 22:12:05       16 阅读
  6. 131分隔

    2024-05-09 22:12:05       18 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-09 22:12:05       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-09 22:12:05       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-09 22:12:05       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-09 22:12:05       20 阅读

热门阅读

  1. 【收录 Hello 算法】3.2 基本数据类型

    2024-05-09 22:12:05       12 阅读
  2. 闰年的数目

    2024-05-09 22:12:05       11 阅读
  3. Robots协议的一点知识

    2024-05-09 22:12:05       11 阅读
  4. 计算机网络chapter2——家庭作业

    2024-05-09 22:12:05       9 阅读
  5. 欧拉角(Euler)和四元数(Quaternion)

    2024-05-09 22:12:05       10 阅读
  6. Nginx启动后不能正常访问

    2024-05-09 22:12:05       11 阅读
  7. 《乔布斯传》读书总结

    2024-05-09 22:12:05       15 阅读
  8. Edge的使用心得与深度探索

    2024-05-09 22:12:05       9 阅读
  9. 完全背包基础题(第三十八天)

    2024-05-09 22:12:05       12 阅读
  10. 代码随想录算法训练营day62

    2024-05-09 22:12:05       12 阅读
  11. 揭秘:抽象类与接口之间的区别与意义

    2024-05-09 22:12:05       12 阅读