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)

相关推荐
白雪茫茫11 分钟前
监督学习、半监督学习、无监督学习算法详解
python·学习·算法·ai
FengyunSky23 分钟前
浅析 空间频率响应 SFR 计算
算法
树下水月31 分钟前
PHP 一种改良版的雪花算法
算法·php·dreamweaver
一只数据集1 小时前
全尺寸人形机器人灵巧手力觉触觉数据集-2908条ROSbag数据覆盖14大应用场景深度解析
大数据·人工智能·算法·机器人
罗西的思考2 小时前
【GUI-Agent】阿里通义MAI-UI 代码阅读(2)--- 实现
人工智能·算法·机器学习
刀法如飞3 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
sali-tec4 小时前
C# 基于OpenCv的视觉工作流-章66-直线夹角
图像处理·人工智能·opencv·算法·计算机视觉
AC赳赳老秦4 小时前
接口测试自动化:用 OpenClaw 对接 Postman,实现批量回归测试、测试报告自动生成与推送
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
_风满楼5 小时前
TDD实战-会议室冲突检测的红绿重构循环
前端·javascript·算法
pq2175 小时前
java实现遗传算法
算法