leetcode练习 分割回文串

给你一个字符串 s,请你将s分割成一些子串,使每个子串都是

回文串

。返回 s 所有可能的分割方案。

示例 1:

复制代码
输入:s = "aab"
输出:[["a","a","b"],["aa","b"]]

示例 2:

复制代码
输入:s = "a"
输出:[["a"]]

提示:

  • 1 <= s.length <= 16
  • s 仅由小写英文字母组成

思路,我们可以采用回溯算法,找到每一个字符串的组合,再判断是否是回文串,在回溯函数中,我们采用一个for循环更新容器大小用来截取字符串长度。

cpp 复制代码
class Solution {
public:
    vector<vector<string>>res;
    vector<string>path;
    bool is_fun(int left,int right,string s){
        if(left>right)return false;
        while(left<right){
            if(s[left]!=s[right])return false;
            left++;
            right--;
        }
        return true;
    }
    void backtracing(int left,int right,string s){
        if(left>right){
            res.push_back(path);
            return ;
        }
        for(int i=0;i<right-left+1;i++){
            if(is_fun(left,left+i,s)){
                path.push_back(s.substr(left,i+1));
                backtracing(left+i+1,right,s);
                path.pop_back();
            }
        }
    }
    vector<vector<string>> partition(string s) {
        backtracing(0,s.size()-1,s);
        return res;
    }
};

给定字符串大小除去上面方法外,我们还可以使用substr函数,我认为这样写更加清晰,在判断是否是回文串时可以直接重新计算字符串的left和right,像上面函数中写的,在调用is_fun函数时,我第一次写时传错参数is_fun(left.i,s)导致开头传错判断错误。

cpp 复制代码
       for(int i=1;i<=right-left+1;i++){
            if(is_fun(s.substr(left,i))){
                path.push_back(s.substr(left,i));
                backtracing(left+i,right,s);
                path.pop_back();
            }
相关推荐
霁月中12 小时前
[Codeforces Round 1065 (Div. 3)](A-D,F)
算法
世洋Blog12 小时前
算法导论-分治法和合并(Merge)排序
算法
源代码•宸12 小时前
Golang基础语法(go语言结构体、go语言数组与切片、go语言条件句、go语言循环)
开发语言·经验分享·后端·算法·golang·go
l1t12 小时前
快速加载CSV文件到数据库的工具pg_csv_loader
数据库·算法
yugi98783812 小时前
基于Matlab的晴空指数计算实现
开发语言·算法·matlab
ADI_OP12 小时前
ADAU1452的开发教程3:常规音频算法的开发(2)
算法·dsp开发·adi dsp中文资料·adi dsp·adi音频dsp·adi dsp开发教程
666HZ66612 小时前
数据结构1.0 数据结构在学什么
数据结构·算法
君义_noip13 小时前
信息学奥赛一本通 1951:【10NOIP普及组】导弹拦截 | 洛谷 P1158 [NOIP 2010 普及组] 导弹拦截
c++·算法·csp-j·信息学奥赛
环黄金线HHJX.13 小时前
《QuantumTuan ⇆ QT:Qt》
人工智能·qt·算法·编辑器·量子计算
jz_ddk13 小时前
[实战] 射频相位噪声单位转换:从dBc/Hz到rad
算法·rf·射频·相位噪声·相噪