zoukankan      html  css  js  c++  java
  • 最长回文子串(时间复杂度略高,有精简算法,欢迎交流。)

    时间限制:1000ms
    单点时限:1000ms
    内存限制:64MB

    描述

       小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相帮助,在编程的学习道路上一同前进。

       这一天,他们遇到了一连串的字符串,于是小Hi就向小Ho提出了那个经典的问题:“小Ho,你能不能分别在这些字符串中找到它们每一个的最长回文子串呢?”

       小Ho奇怪的问道:“什么叫做最长回文子串呢?”

       小Hi回答道:“一个字符串中连续的一段就是这个字符串的子串,而回文串指的是12421这种从前往后读和从后往前读一模一样的字符串,所以最长回文子串的意思就是这个字符串中最长的身为回文串的子串啦~”

       小Ho道:“原来如此!那么我该怎么得到这些字符串呢?我又应该怎么告诉你我所计算出的最长回文子串呢?

       小Hi笑着说道:“这个很容易啦,你只需要写一个程序,先从标准输入读取一个整数N(N<=30),代表我给你的字符串的个数,然后接下来的就是我要给你的那N个字符串(字符串长度<=10^6)啦。而你要告诉我你的答案的话,只要将你计算出的最长回文子串的长度按照我给你的顺序依次输出到标准输出就可以了!你看这就是一个例子。”

    样例输入
    3
    abababa
    aaaabaa
    acacdas
    样例输出
    7
    5
    3
     1 import java.util.Scanner;
     2 
     3 
     4 public class Main {
     5 
     6     
     7     public static void main(String [] argv){        
     8     Scanner in = new Scanner(System.in);
     9     int num = Integer.parseInt(in.nextLine());
    10     String[] ks =new String[num];
    11     for (int i=0; i<num; i++){
    12         ks[i]=in.nextLine();        
    13     }
    14     in.close();
    15     for (int i=0; i<num; i++){
    16         int max=1;
    17         char[] k=ks[i].toCharArray();
    18         int[][] s = new int [k.length][k.length+1];
    19         for(int x=0; x<ks[i].length();x++){
    20             s[x][1]=1; s[x][0]=1;
    21         }
    22         for(int t=1; t<k.length; t++){            
    23           for(int y=0;y<t; y++){
    24               if((s[t-1][y]==1)&&(k[t]==(k[t-y-1]))){
    25                   s[t][y+2]=1;
    26                   if(y+2>max)
    27                       max=y+2;
    28               }              
    29           }        
    30         }
    31         System.out.println(max);    
    32     }
    33     
    34  }
    35 
    36 }

  • 相关阅读:
    【Java8】 @FunctionalInterface 函数式接口
    集合使用copy与mutableCopy的区别
    GCD中的dispatch_sync、dispatch_sync 分别与串行、并行队列组合执行小实验
    podspec文件介绍
    iOS系统app崩溃日志手动符号化
    webView文本长按显示英文
    深拷贝
    view向全屏延伸时的属性设置
    iOS 模拟器截屏快捷键
    mysql 优化常用语句
  • 原文地址:https://www.cnblogs.com/udld/p/4226038.html
Copyright © 2011-2022 走看看