zoukankan      html  css  js  c++  java
  • leetcode——5.最长回文子串

    早上两个小时才写出来,但是运行超时。。。

    感觉自己是真的不会算法,应该系统学习一下才对。

    代码我先粘在这里,然后慢慢优化:

    要加油哦,学算法!!!!!

                                                                          ——2019.9.20

    之前的惨不忍睹,已删。

    方法一,暴力法,重点就是判断一个字符串是否是回文子串,以及设置两个参数来返回最后结果,

    即,只需要记录回文串的起始位置和字符串长度即可。

    然后在遍历的时候,只考虑当前字符串长度大于已知的最大长度的情况,代码如下:

    class Solution {
        public String longestPalindrome(String s) {
            //暴力解法
            int len = s.length();
            //最后走只需要记录其实下标以及字符串长度即可得到答案
            int begin = 0;
            int strLen = 1;
            if(len < 2){
                return s;
            }//长度为0 和1 的字符串直接输出本身
            for(int i = 0;i<len - 1;i++){
                for(int j = i+1;j<len;j++){
                    //判断回文子串的函数
                    //判断从起始位置i到终止位置j的字符串是否是回文字符串
                    if(j-i+1>strLen && isPalindromic(s,i,j)){
                        begin = i;
                        strLen = j-i+1;
                    }
                }
            }
            return s.substring(begin,begin+strLen);
        }
    
        private boolean isPalindromic(String s, int begin, int end) {
            while(begin < end){
                if(s.charAt(begin) != s.charAt(end)){
                    return false;
                }
                begin ++;
                end --;
            }
            return true;
        }
    }

     方法二,中心扩展法

    class Solution {
        public String longestPalindrome(String s) {//中心扩散法分为奇数中心和偶数中心两种情况,但是可以统一来讨论;
            int len = s.length();
            if(len<2){
                return s;
            }
            int begin = 0;
            int maxLen = 1;  //以上部分与暴力法是想相同的
            for(int i = 0;i<len-1;i++){  //遍历中心位置下标   还需要有一个函数来判断字符串是否是回文子串,从中心向两边扩散的方法
                int oddLen = expandAcountCenter(s,i,i);  //奇数中心位
                int evenLen = expandAcountCenter(s,i,i+1);  //偶数中心位
                if(Math.max(oddLen,evenLen) > maxLen){
                    maxLen = Math.max(oddLen,evenLen);
                    begin = i - (maxLen -1) / 2;
                }
            }
            return s.substring(begin,begin + maxLen);
        }
    
        private int expandAcountCenter(String s, int left, int right) {
            int len = s.length();
            while(left >= 0  && right < len){
                if(s.charAt(left) == s.charAt(right)){
                    left --;
                    right ++;
                }else{
                    break;
                }
            }
            return right-left-1;
        }
    }

    中心扩展法分为奇数偶数的情况。

    方法三:动态规划

    public String longestPalindrome(String s) {
            //动态规划
            int len = s.length();
            if(len < 2){
                return s;
            }
            int maxLen = 1;
            int begin = 0;
            boolean[][] dp = new boolean[len][len];
            for(int i = 0;i<len;i++){
                dp[i][i] = true;
            }
            for(int j = 1;j<len;j++) {
                for (int i = 0; i < len; i++) {
                    if(s.charAt(i) != s.charAt(j)){
                        dp[i][j] = false;
                    }else{
                        if(j-i<3){
                            dp[i][j] = true;
                        }else{
                            dp[i][j] = dp[i+1][j-1];
                        }
                    }
                    if(dp[i][j] && j-i+1 > maxLen){
                        maxLen = j-i+1;
                        begin = i;
                    }
                }
            }
            return s.substring(begin,begin + maxLen);
        }

    ——2020.7.7


    public String longestPalindrome(String s) {
            int len = s.length();
            if(len == 0) return "";
            char[] c = s.toCharArray();
            String str = "";
            for(int i = 0;i<len;i++){
                String s1 = isPalindrome(c,i,i,len);
                String s2 = isPalindrome(c,i-1,i,len);
                if(s1.length()>str.length()){
                    str = s1;
                }
                if(s2.length()>str.length()){
                    str = s2;
                }
            }
            return str;
        }
    
        private String isPalindrome(char[] c,int start,int end,int len){
            if(start<0){
                return String.valueOf(Arrays.copyOfRange(c,0,end));
            }
            if(end>=len){
                return String.valueOf(Arrays.copyOfRange(c,start,end));
            }
            while (start>=0 && end<len) {
                if (c[start] == c[end]) {
                    start--;
                    end++;
                }else{
                    return String.valueOf(Arrays.copyOfRange(c,start+1,end));
                }
            }
            return String.valueOf(Arrays.copyOfRange(c,start+1,end));
        }

     还是我自己最后写的这个方法性能最好一点。

     ——2020.8.31

    我的前方是万里征途,星辰大海!!
  • 相关阅读:
    开发脚本自动部署及监控
    内存进程与软件包安装
    Linux常用指令
    网络协议
    Python基础(二)
    python基础(一)
    shell编程
    正则与sed,grep,awk三剑客
    网络配置和元字符
    nginx
  • 原文地址:https://www.cnblogs.com/taoyuxin/p/11556102.html
Copyright © 2011-2022 走看看