leetcode 131. 分割回文串

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

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

 

示例 1:

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

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

提示:

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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/palindrome-partitioning
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

 

    public List<List<String>> partition(String s) {
        List<List<String>> all = new ArrayList<>();
        int length = s.length();
        List<String> list = new ArrayList<>();
        list.add(s.substring(0, 1));
        all.add(list);
        for (int i = 1; i < length; i++) {
            String str = String.valueOf(s.charAt(i));
            List<List<String>> copy = new ArrayList<>();
            for (List<String> a : all) {
                int size = a.size();
                String last1 = a.get(size - 1);
                if (last1.equals(str)) {
                    list = copy(a, size - 1);
                    list.add(str + str);
                    copy.add( list);
                }
                if (size > 1) {
                    String last2 = a.get(size - 2);
                    if (last2.equals(str)) {
                        list = copy(a, size - 2);
                        list.add(str +last1 + str);
                        copy.add( list);
                    }
                }
                a.add(str);
            }
            all.addAll(copy);
        }
        return all;
    }

        private static List<String> copy (List<String> list, int limit){

        List<String> other = new ArrayList<>(limit + 1);
        for (int i = 0; i < limit; i++) {
            other.add(list.get(i));
        }
        return other;
    }

posted @ 2021-04-26 18:00  旺仔古李  阅读(53)  评论(0编辑  收藏  举报