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

    算法1。动态规划

    dp[i][j] 表示的是 从i 到 j 的字串,是否是回文串。

    则根据回文的规则我们可以知道:

    如果s[i] == s[j] 那么是否是回文决定于 dp[i+1][ j - 1]

    当 s[i] != s[j] 的时候, dp[i][j] 直接就是 false。

    动态规划的进行是按照字符串的长度从1 到 n推进的。

    代码很明晰:给出java代码,复杂度 O(n^2)

    public class Solution {
        boolean[][] dp;    
    	public String longestPalindrome(String s)
    	{
    		if(s.length() == 0)
    		{
    			return "";
    		}
    		if(s.length() == 1)
    		{
    			return s;
    		}
    		dp = new boolean[s.length()][s.length()];		
    		int i,j;		
    		for( i = 0; i < s.length(); i++)
    		{
    			for( j = 0; j < s.length(); j++)
    			{
    				if(i >= j)
    				{
    					dp[i][j] = true; //当i == j 的时候,只有一个字符的字符串; 当 i > j 认为是空串,也是回文
    				}
    				else
    				{
    					dp[i][j] = false; //其他情况都初始化成不是回文
    				}
    			}
    		}		
    		int k;
    		int maxLen = 1;
    		int rf = 0, rt = 0;
    		for( k = 1; k < s.length(); k++)
    		{
    			for( i = 0;  k + i < s.length(); i++)
    			{
    				j = i + k;
    				if(s.charAt(i) != s.charAt(j)) //对字符串 s[i....j] 如果 s[i] != s[j] 那么不是回文
    				{
    					dp[i][j] = false;
    				}
    				else  //如果s[i] == s[j] 回文性质由 s[i+1][j-1] 决定
    				{
    					dp[i][j] = dp[i+1][j-1];
    					if(dp[i][j])
    					{
    						if(k + 1 > maxLen)
    						{
    							maxLen = k + 1;
    							rf = i;
    							rt = j;
    						}
    					}
    				}
    			}
    		}
    		return s.substring(rf, rt+1);
    	}
    }
    
  • 相关阅读:
    数据存储检索之B+树和LSM-Tree
    Kylin构建Cube过程详解
    关于maven打包乱码报错问题解决
    很详尽KMP算法 转载
    计算机源码反码补码
    Lombok实现链式编程 转载
    java适配器模式
    ubuntu卸载软件步骤(转)
    JMeter压测的使用
    @valid注解的使用(转载)
  • 原文地址:https://www.cnblogs.com/tgkx1054/p/3091393.html
Copyright © 2011-2022 走看看