leetcode——132. 分割回文串 II

public int minCut(String s) {
        int n = s.length();
        int[] f = new int[n+1];
        boolean[][] p = new boolean[n][n];
        for (int i = 0;i<= n;i++){
            f[i] = n-1-i;
        }
        for(int i = n-1;i>=0;i--){
            for(int j = i;j<n;j++){
                if(s.charAt(i) == s.charAt(j) && (j-i<2||p[i+1][j-1])){
                    p[i][j] = true;
                    f[i] = Math.min(f[i],f[j+1]+1);
                }
            }
        }
        return f[0];
    }

 

 

 

 

 

确实难。。

——2020.6.24

posted @ 2020-06-24 23:02  欣姐姐  阅读(134)  评论(0编辑  收藏  举报