ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

leetcode 131. 分割回文串

2022-02-17 15:01:27  阅读:172  来源: 互联网

标签:cur int List 131 boolean new leetcode 回文


一、题目

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

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

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

二、解法

思路:回溯。
其中需要判断s[i:j]是否是回文串。可以用动态规划来存储。

class Solution {
    List<List<String>> ans=new ArrayList<>();
    List<String> cur=new ArrayList<>();
    boolean[][] f;

    public List<List<String>> partition(String s) {
        int n=s.length();
        f=new boolean[n][n];
        for(int i=0;i<n;i++){
            for(int j=0;j<n;j++) f[i][j]=true;
        }
        for(int i=n-1;i>=0;i--){
            for(int j=i+1;j<n;j++){
                f[i][j]=f[i+1][j-1]&&s.charAt(i)==s.charAt(j);
            }
        }

        dfs(s,0);
        return ans;
    }

    void dfs(String s,int index){
        if(index==s.length()){
            ans.add(new ArrayList<>(cur));
            return;
        }
        for(int i=index;i<s.length();i++){
            String str=s.substring(index,i+1);
            if(f[index][i]){
                cur.add(str);
                dfs(s,i+1);
                cur.remove(cur.size()-1);
            }
        }
    }
}

标签:cur,int,List,131,boolean,new,leetcode,回文
来源: https://www.cnblogs.com/livingsu/p/15904647.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有