Leetcode 131 Palindrome Partition

题意

把一个字符串分割成多个回文字符串的partition,返回所有的可能partion

链接

https://leetcode.com/problems/palindrome-partitioning/description/

思考

这只是dfs套了一个回文问题

题解

dfs每次截取一段字符串,判断是否是回文

退出条件是遍历到末尾了

dfs传入起始位置u, 从第u位开始截取字符串,一直到末尾,末尾有个指针i。一旦发现是回文了就可以继续截取回文。下一个dfs是从第i+1开始

cpp 复制代码
class Solution {
public:
    vector<vector<string>> res;
    vector<vector<string>> partition(string s) {
        vector<string> tmp;
        dfs(0, s, tmp);
        return res;
    }
    void dfs(int u, string s, vector<string>& tmp) {
        if( u == s.size()) {
            res.push_back(tmp);
        }
        for(int i = u; i < s.size(); i++) {
            if(isPalidrome(s, u, i)) {
                string tmpStr = s.substr(u, i-u+1);
                tmp.push_back(tmpStr);
                dfs(i+1, s, tmp);
                tmp.pop_back();
            }
        }
    }
    bool isPalidrome(string s, int u, int i) {
        int l = u;
        int r = i;
        while(l < r) {
            if(s[l] == s[r]) {
                l++;
                r--;
            } else {
                return false;
            }
        }
        return true;
    }
};

时间复杂度 O ( n ∗ 指数级别 ) O(n*指数级别) O(n∗指数级别)

空间复杂度 O ( n ) O(n) O(n)

相关推荐
MoonBit月兔21 分钟前
双周报Vol.70: 运算符重载语义变化、String API 改动、IDE Markdown 格式支持优化...多项更新升级!
ide·算法·哈希算法
How_doyou_do25 分钟前
树状数组底层逻辑探讨 / 模版代码-P3374-P3368
数据结构·算法·树状数组
小鹿鹿啊1 小时前
C语言编程--14.电话号码的字母组合
c语言·开发语言·算法
小O的算法实验室1 小时前
2024年ESWA SCI1区TOP:量子计算蜣螂算法QHDBO,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
C语言魔术师1 小时前
509. 斐波那契数
算法·动态规划
共享家95271 小时前
栈相关算法题解题思路与代码实现分享
c++·leetcode
Wendy_robot1 小时前
【前缀和计算和+哈希表查找次数】Leetcode 560. 和为 K 的子数组
c++·算法·leetcode
o独酌o1 小时前
算法习题-力扣446周赛题解
算法·leetcode
一只鱼^_2 小时前
第十六届蓝桥杯大赛软件赛省赛 C/C++ 大学B组 [京津冀]
c语言·数据结构·c++·算法·贪心算法·蓝桥杯·动态规划