当前位置: 首页 > article >正文

131. 分割回文串

题目描述

给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。

回文串 是正着读和反着读都一样的字符串。

示例 1:

输入:s = "aab"
输出:[["a","a","b"],["aa","b"]]

示例 2:

输入:s = "a"
输出:[["a"]]

提示:

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

解答

class Solution {
public:
    vector<vector<string>> res;
    vector<string> path;
    vector<vector<string>> partition(string s) {
        res.clear();
        path.clear();
        backtrack(s, 0);
        return res;
    }

    void backtrack(string &s, int startidx)
    {
        // 分割起点大于等于字符串长度就说明本次分割完成,得到一组结果
        if(startidx >= s.size())
        {
            res.push_back(path);
            return;
        }

        // i 从 startidx 出发判断 [startidx, i]构成的字符串是否回文
        // 若是则加入临时结果中,进行后续的分割
        for(int i = startidx; i < s.size(); i++)
        {
            if(isPalindrome(s, startidx, i))
            {
                string str = s.substr(startidx, i - startidx + 1);
                path.push_back(str);
            }   
            else
            {
                continue;
            }
            backtrack(s, i + 1);
            path.pop_back();
        }
    }

    bool isPalindrome(string &str, int start, int end)
    {
        for(int i = start, j = end; i < j; i++, j--)
        {
            if(str[i] != str[j]) return false;
        }
        return true;
    }
};

http://www.kler.cn/a/156953.html

相关文章:

  • 重新认识HTTPS
  • 【Python】爬虫通过验证码
  • 7天用Go从零实现分布式缓存GeeCache(学习)(3)
  • 如何在 Ubuntu 16.04 上设置 NFS 挂载
  • 鸿蒙华为商城APP案例
  • 基于STM32的智能充电桩:集成RTOS、MQTT与SQLite的先进管理系统设计思路
  • JMeter从入门到精通
  • 个人Windows电脑通过Cloudreve+Cpolar搭建PHP云盘系统公网可访问
  • 机器学习(1)机器学习类型和机器学习的主要概念
  • 练习十一:简单卷积器的设计
  • 纯C读取文件实现解析H264裸流每一帧数据
  • 回归分析:预测和建模
  • Git 简介及异常场景处理
  • 12月4日作业
  • 作业12.4
  • 分享77个菜单导航JS特效,总有一款适合您
  • JDBC常见的几种连接池使用(C3P0、Druid、HikariCP 、DBCP)(附上代码详细讲解)
  • 软件测试【理论基础】
  • 基于AT89C51单片机的秒表设计
  • Python机器学习、深度学习入门丨气象常用科学计算库、气象海洋常用可视化库、爬虫和气象海洋数据、气象海洋常用插值方法、EOF统计分析、WRF模式后处理等
  • Stream 流
  • 【Vue】Linux 运行 npm run serve 报错 vue-cli-service: Permission denied
  • Django总结
  • 【bug排查解决】现象级延迟8-10s
  • 编程语言中常量(Constant)简介
  • Python (十八) 正则表达式