首页 > 其他 > 详细

动态规划-Minimum Insertion Steps to Make a String Palindrome

时间:2020-01-05 13:05:16      阅读:88      评论:0      收藏:0      [点我收藏+]

2020-01-05 11:52:40

问题描述:

技术分享图片

问题求解:

好像多次碰到类似的lcs的变种题了,都是套上了回文的壳。这里再次记录一下。

其实本质就是裸的lcs,就出结果了。

    public int minInsertions(String s) {
        StringBuffer sb = new StringBuffer(s);
        String b = sb.reverse().toString();
        return s.length() - lcs(s, b);
    }
    
    public int lcs(String str1, String str2) {  
        int len1 = str1.length();  
        int len2 = str2.length();  
        int c[][] = new int[len1+1][len2+1];  
        for (int i = 0; i <= len1; i++) {  
            for( int j = 0; j <= len2; j++) {  
                if(i == 0 || j == 0) {  
                    c[i][j] = 0;  
                } else if (str1.charAt(i-1) == str2.charAt(j-1)) {  
                    c[i][j] = c[i-1][j-1] + 1;  
                } else {  
                    c[i][j] = Math.max(c[i - 1][j], c[i][j - 1]);  
                }  
            }  
        }  
        return c[len1][len2];  
    }

  

 

动态规划-Minimum Insertion Steps to Make a String Palindrome

原文:https://www.cnblogs.com/hyserendipity/p/12151915.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!