1.题目描述

Given a string s, partition s such that every substring of the partition is a palindrome.

Return all possible palindrome partitioning of s.

For example, given s = "aab",
Return

  [
["aa","b"],
["a","a","b"]
]
也就是给定一个字符串,找出所有可能的划分,每一个划分的每一个字串都是回文串。设这个划分函数为partition_index(string s,int begin,int end)

2.解题思路

蛮力法当然是可以解决这个问题,对于一个长度为n的字符串,有2n-1种划分方法,只需要判断每种划分是否满足条件即可,虽然不知道暴力法能不能在系统里面ac掉,但是这样显然不是一个正常的程序员该干的事。不过蛮力法会给我们一些启示。我们从为什么蛮力法会有2n-1种划分方法开始分析。

当然,这也很容易分析,对于长度为n的字符串s0s1…sk…sn-1,在sk和sk-1之间我们可以选择截断与不截断,但是,我们可以基于这个思路理出一个递归的思路,那就是,对于字符串sbeginsbegin+1…sbegin+k…sn-1,所有可能满足条件的划分分为两类:

(1)在sbegin和sbegin+1之间有隔断,这种情况,只需sbegin和partition_index(s,begin+1,n-1)连接起来即可

(2)在sbegin和sbegin+1之间无隔断,这种情况,需找到至少包含sbegin和sbegin+1的一个回文字符串,如果能够找到,比如,sbegin…sbegin+k是一个回文字符串,那么,将这个回文字符串和partition_index(s,k+1,n-1)连接起来,注意,可能找到不止一个包含s0和s1的回文字符串,那么有多少个,就多出多少类划分可能;如果找不到,那么返回空vector.

3.代码

#include <iostream>

#include <vector>

#include <string>

#include <iterator>

using namespace std;

vector<vector<string> > partition(string s);

vector<vector<string> > partition_index(string s, int begin, int end);

bool isPalindrome(string s, int begin,int end);

int main()

{

    partition("cdd");

    return 0;

}

 

vector<vector<string> > partition(string s) {

 

    return partition_index(s,0,s.length()-1);

    

}

 

vector<vector<string> > partition_index(string s, int begin, int end)

{

    vector<vector<string> > result;

 

    //边界条件

    if(begin == end)

    {

        vector<string> item;

        item.push_back(s.substr(begin,1));       

        result.push_back(item);

        return result;

    }

    if(begin > end) return result;

    

    //如果在begin与begin+1之间有划分

    vector<vector<string> > result_part1;

    result_part1 = partition_index(s,begin+1,end);

    if(!result_part1.empty())

    {

        vector<vector<string> >::iterator iter_vv;

        for(iter_vv = result_part1.begin();iter_vv!=result_part1.end();++iter_vv)

        { 

            vector<string> temp;

            //temp = *iter_vv;

            temp.push_back(s.substr(begin,1));

            

            vector<string>::iterator iter_v;

            for(iter_v = (*iter_vv).begin();iter_v!= (*iter_vv).end();++iter_v)

            {

                temp.push_back(*iter_v);

            }

            result.push_back(temp);

        }

    }

    

    

    //如果在begin和begin+1之间无划分

    int nextSeg = begin +1;

    while(nextSeg<=end)

    {

 

        //找到了回文字符串

        if(isPalindrome(s,begin,nextSeg))

        {

            vector<vector<string> >result_part2_1;

            result_part2_1  = partition_index(s,nextSeg+1,end);

            if(!result_part2_1.empty())

            {

                vector<vector<string> >::iterator iter_vv;

                for(iter_vv = result_part2_1.begin();iter_vv!=result_part2_1.end();++iter_vv)

                {

                    vector<string> temp;

              //      temp = *iter_vv;

                    temp.push_back(s.substr(begin,nextSeg));

            

                    vector<string>::iterator iter_v;

                    for(iter_v = (*iter_vv).begin();iter_v!= (*iter_vv).end();++iter_v)

                    {

                        temp.push_back(*iter_v);

                    }

                    result.push_back(temp);

                }

                

            }

            else

            {

                vector<string>temp;

                temp.push_back(s.substr(begin,nextSeg-begin+2));

                result.push_back(temp);

            }

        }

        //继续找看是否有其他的更长的回文字符串

        nextSeg++;

    }

    

    return result;

        

}

 

 

//判断字符串由begin 和end 确定的字串是否为回文字符串

bool isPalindrome(string s, int begin,int end)

{

    if(begin>end)return false;

    if(begin==end)return true;

    if((begin+1)==end)return s[begin]==s[end];

    else

        if(s[begin]==s[end])

            return isPalindrome(s,begin+1,end-1);

        esle return false;

}

 

 

另外,代码可以简化,比如,连接结果的代码可以封装成一个函数.

leetcode—Palindrome 解题报告的更多相关文章

  1. LeetCode: Permutations 解题报告

    Permutations Given a collection of numbers, return all possible permutations. For example,[1,2,3] ha ...

  2. 【LeetCode】409. Longest Palindrome 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 方法一:字典统计次数 方法二:HashSet 方法三 ...

  3. 【LeetCode】214. Shortest Palindrome 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 前缀是否回文 判断前缀 相似题目 参考资料 日期 题 ...

  4. 【LeetCode】125. Valid Palindrome 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 解题方法 列表生成式 正则表达式 双指针 日期 题目地址:https:/ ...

  5. LeetCode: Valid Palindrome 解题报告

    Valid Palindrome Given a string, determine if it is a palindrome, considering only alphanumeric char ...

  6. LeetCode C++ 解题报告

    自己做得LeetCode的题解,使用C++语言. 说明:大多数自己做得,部分参考别人的思路,仅供参考; GitHub地址:https://github.com/amazingyyc/The-Solut ...

  7. C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告

    剑指offer之面试题37 两个链表的第一个公共结点 提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?t ...

  8. LeetCode: Subsets 解题报告

    Subsets Given a set of distinct integers, S, return all possible subsets. Note: Elements in a subset ...

  9. LeetCode: Triangle 解题报告

    Triangle Given a triangle, find the minimum path sum from top to bottom. Each step you may move to a ...

随机推荐

  1. Javascript和ECMAScript二三事

    来自<javascript高级程序设计 第三版:作者Nicholas C. Zakas>的学习笔记(一) Javascript是一种专为与网页交互而设计的脚本语言,由下列三个不同部分组成: ...

  2. ural 1160

    最小生成树  第一次敲 套用几个函数 其实挺容易的 #include <cstdio> #include <cstring> #include <vector> # ...

  3. 线程以及数据对象的wait()和notifyAll()方法

    正在运行的程序称作一个进程,一个进程可以包含多个线程,这些线程可以共享进程的资源,它们共用一块存储空间.那么,各个线程在访问同一个数据对象的同时,可能引起冲突,以生产者.消费者为例,就会出现队列中没有 ...

  4. Tiny6410 LED字符设备驱动

    1.查看用户手册 led1.led2.led3.led4 连接的分别是 GPK4.GPK5.GPK6.GPK7 2.查询6410芯片手册 下面还需要3个步骤: 1.设置GPIO为OUTPUT. 将GP ...

  5. linux fork函数与vfork函数

    一.fork1. 调用方法#include <sys/types.h>#include <unistd.h> pid_t fork(void);正确返回:在父进程中返回子进程的 ...

  6. php获取类的实例变量

    <?php class Page {private $title; //构造函数固定名称为__construct,这样能将php的类构造函数独立于类名,以后修改类名就无需修改构造函数名称 fun ...

  7. spring aop环绕通知

    [Spring实战]—— 9 AOP环绕通知   假如有这么一个场景,需要统计某个方法执行的时间,如何做呢? 典型的会想到在方法执行前记录时间,方法执行后再次记录,得出运行的时间. 如果采用Sprin ...

  8. ArcGIS学习记录—ArcGIS ArcMap编辑状态中线打断的问题

    摘要:在处理数据时,我们经常会遇到线打断的问题,比如需要指定在线上某处打断线,或者新建网络数据集时需要在线的交点处打段线等等.现将桌面版中我所遇到的线打断的工具总结如下: 在ArcGIS矢量处理数据时 ...

  9. 发现可高速缓存的 SSL 页面

    发现可高速缓存的 SSL 页面 技术描述: 缺省情况下,大部分 Web 浏览器都配置成会在使用期间高速缓存用户的页面. 这表示也会高速缓存 SSL 页面.不建议让 Web 浏览器保存任何 SSL 信息 ...

  10. Android中Input型输入设备驱动原理分析<一>

    话说Android中Event输入设备驱动原理分析还不如说Linux输入子系统呢,反正这个是没变的,在android的底层开发中对于Linux的基本驱动程序设计还是没变的,当然Android底层机制也 ...