leetCode解题报告



题目:




Palindrome Partitioning  I


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"]
  ]


分析:


题意给我们一个字符串,求出所有这个字符串的子串,并且子串都为回文字符串的情况,输出它的集合结果






解题思路:(跟DFS深度遍历有点像!)


字符串Str = "aab";


分析了题目的数据之后,我们知道它的结果,可能是 a, a, b 或者  aa, b 这样的情况!


也就是说,我们需要去考虑 i = 1,  2 ....  n 的情况,比如


Str = "aaa"


结果集




[[a, a, a], [a, aa], [aa, a], [aaa]]


根据这样的情况,我们用类似于DFS的算法


str1 = str.substr(0, i); 取出前面下标从 0 开始到 i 结束的子串,判断str1是否满足回文字符串的要求,


1. 满足:这样子,有可能成为一种分割的情况,所以我们new出一个list集合,把str1放入到list中,然后我们求出str剩余的子串  str2 = str.substr(i); 取出前面下标从 i 开始到整个字符串结尾的子串, 然后将str2 作为新的字符串,同时把list集合也传入到函数中,递归调用。递归的结束条件就是到传入的这个字符串的长度为0(这样就意味着已经到了字符串的末尾了),此时证明这种情况下得到的list集合是满足条件的,我们把这个list集合 加入到 结果集合result中。


2. 不满足的话,继续 i++, 直到 i == str.length();


3. 全部结束之后,返回 最终的结果集合 result

你可能感兴趣的:(leetCode解题报告)