leetcode131. 分割回文串

一:题目

在这里插入图片描述

二:思路

1.分析题意:这里是给定我们一个字符串 我们输出的结果是 切割不同的位置 来得到不同的字符串
然后这些字符串是要是回文字符串 所以我们需要一个函数去判断我们输入的字符串是否是回文
字符串(这里用双指针法来判断是否为回文字符串)
2.递归回溯来解决
vector<vector >ans;
vector path;
1>:确定递归函数的参数
void backstacking(string &str,int index)
2>:确定回溯终止条件
//当我们的切割线是在字符串的末尾的时候,这时候就已经得到一种结果
if(index >= str.size()){
ans.push_back(path);
return ;
}
3>:单层逻辑
for(int i = index; i < s.size(); i++) {
//首先判断是否是回文串
if(IsPalindromeString(s,index,i)){
string str = s.substr(index,i-index+1);//第一个参数是起始位置
//第二个参数是截取的几个字符
path.push_back(str);
}else {
continue;
}

backstacking(str,i+1);
path.pop_back();
}
//判断回文字符串
bool IsPalindromeString(string &s,int start,int end) {
for(int i = start,j = end; i < j; i++,j–) {
if(s[i] != s[j]) {
return false;
}
}
return true;
}

三:上码

class Solution {
public:
    /**
        思路:
        1.分析题意:这里是给定我们一个字符串 我们输出的结果是  切割不同的位置  来得到不同的字符串
          然后这些字符串是要是回文字符串 所以我们需要一个函数去判断我们输入的字符串是否是回文
          字符串(这里用双指针法来判断是否为回文字符串)
        2.递归回溯来解决
          vector<vector<int> >ans;
          vector<string> path;
          1>:确定递归函数的参数
            void backstacking(string &str,int index)
          2>:确定回溯终止条件 
            //当我们的切割线是在字符串的末尾的时候,这时候就已经得到一种结果
            if(index >= str.size()){
                ans.push_back(path);
                return ;
            }
           3>:单层逻辑
            for(int i = index; i < s.size(); i++) {
                //首先判断是否是回文串
                if(IsPalindromeString(s,index,i)){
                    string str = s.substr(index,i-index+1);//第一个参数是起始位置 
                                                         //第二个参数是截取的几个字符
                    path.push_back(str);
                }else {
                    continue;
                }

                backstacking(str,i+1);
                path.pop_back();
            }
            //判断回文字符串
            bool IsPalindromeString(string &s,int start,int end) {
                for(int i = start,j = end; i < j; i++,j--) {
                    if(s[i] != s[j]) {
                        return false;
                    }
                }
                return true;
            }
    */

    vector<vector<string> >ans;
    vector<string> path;
    void backstacking(string &s,int index) {
        if(index >= s.size()){
            ans.push_back(path);
            return ;
        }

         for(int i = index; i < s.size(); i++) {
            //首先判断是否是回文串
            if(IsPalindromeString(s,index,i)){
                string str = s.substr(index,i-index+1);//第一个参数是起始位置 
                                                        //第二个参数是截取的几个字符
                path.push_back(str);
            }else {
                continue;
            }
            backstacking(s,i+1);
            path.pop_back();
        }

    }

     bool IsPalindromeString(string &s,int start,int end) {
                for(int i = start,j = end; i < j; i++,j--) {
                    if(s[i] != s[j]) {
                        return false;
                    }
                }
                return true;
     }
    vector<vector<string>> partition(string s) {

    //   string str = "abcdef";
    //   string ss = str.substr(1,4);
    //   cout << ss;
    //     return {};

    backstacking(s,0);

    return ans;
    }
};

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天天向上的菜鸡杰!!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值