zoukankan      html  css  js  c++  java
  • [leetcode] Longest Palindromic Substring

    题目:(String)

    Given a string S, find the longest palindromic substring in S. You may assume that the maximum length of S is 1000, and there exists one unique longest palindromic substring.

    题解:自己先写了一个循环所有substring的,超时。

    public class Solution {
        public String longestPalindrome(String s) {
            if(s.length()==0||s.length()==1||checkIsPalindrome(s))
               return s;
            
            int len = s.length();
            
            for(int i =len-1 ; i>=1 ;i--)
            {
                for(int j =0; j<=len-i; j++)
                {
                    if(checkIsPalindrome(s.substring(j,j+i)))
                      return s.substring(j,j+i);
                }
            }
            
            return s;
        }
        
        public boolean checkIsPalindrome(String s)
        {
            Stack<Character> stack = new Stack<Character>();
            int len =s.length();
            if(len%2==0)
            {
                for(int i=0;i<len/2;i++)
                {
                    stack.push(s.charAt(i));
                }
                
                for(int i=len/2;i<len;i++)
                {
                    char temp = stack.pop();
                    if(temp!=s.charAt(i))
                       return false;
                }
                return true;
            }
            else
            {
                for(int i=0;i<len/2;i++)
                {
                    stack.push(s.charAt(i));
                }
                
                for(int i=len/2+1;i<len;i++)
                {
                    char temp = stack.pop();
                    if(temp!=s.charAt(i))
                       return false;
                }
                return true;
            }
        }
    }

    看了别人的方法:

    第二种方法“是对于每个子串的中心(可以是一个字符,或者是两个字符的间隙,比如串abc,中心可以是a,b,c,或者是ab的间隙,bc的间隙,例如aba是回文,abba也是回文,这两种情况要分情况考虑)往两边同时进 行扫描,直到不是回文串为止。假设字符串的长度为n,那么中心的个数为2*n-1(字符作为中心有n个,间隙有n-1个)。对于每个中心往两边扫描的复杂 度为O(n),所以时间复杂度为O((2*n-1)*n)=O(n^2),空间复杂度为O(1)。”引自Code ganker(http://codeganker.blogspot.com/2014/02/longest-palindromic-substring-leetcode.html)

    public class Solution {
        public String longestPalindrome(String s) {
            if(s.length()==0||s.length()==1)
               return s;
              
            String longest = s.substring(0,1);
            for(int i=0;i<s.length(); i++)
            {
                String temp = buildTheLargeSubstring(s,i,i);
                
                if(temp.length()>longest.length())
                   longest =temp;
                   
                temp = buildTheLargeSubstring(s,i,i+1);
                
                if(temp.length()>longest.length())
                   longest =temp;
            }
            
            return longest;
        }
        
        public String buildTheLargeSubstring(String s, int begin, int end)
        {
            while(begin>=0&&end<=s.length()-1&&s.charAt(begin)==s.charAt(end))
            {
                begin--;
                end++;
            }
            
            return s.substring(begin+1,end);
        }
    }
  • 相关阅读:
    .net core在linux下图片中文乱码
    微信公众号开发--.net core接入
    洛谷P3385负环
    洛谷P3387缩点
    洛谷P2312解方程
    洛谷P3366最小生成树
    洛谷P3378堆
    洛谷P2024食物链
    洛谷P2680运输计划
    洛谷P2886牛继电器
  • 原文地址:https://www.cnblogs.com/fengmangZoo/p/4183793.html
Copyright © 2011-2022 走看看