一个Java源文件,类名为RepeatSubstring,其中public static int FindMax(String S)函数为算法执行的函数。
题目内容: 作为依依的好朋友,技术男沛沛在依依生日时送给他一个超长字符串 S 。沛沛要依依在其中找出一个最长的字符串 T ,使得 T 在 S 中至少出现了两次,而他想说的秘密就藏在 T 中。
由于字符串实在是太长了,依依总是找不到合适的 T 。于是依依请你帮他找到这个 T 的长度。
【输入格式】
一行。一个字符串,即题目中说的S 。
【输出格式】
一行。一个整数,表示最长的 T 的长度。
【样例输入】
ababa
【样例输出】
3
「数据范围」
对于 30% 的数据,S长度 <= 100
对于 60% 的数据,S长度 <= 8000
对于 100% 的数据,S长度 <= 50000
一样的问题:http://ask.csdn.net/questions/156615
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
string s = "依依我不爱你还能爱谁,依依我不爱你才怪";
var query = Enumerable.Range(0, s.Length).Select(x => s.Substring(x)).OrderBy(x => x).ToArray();
int idx = 0; int max = 0;
for (int i = 1; i < query.Length; i++)
{
int same = query[i].Zip(query[i - 1], (x, y) => x == y).TakeWhile(x => x).Count();
if (same > max)
{
idx = i; max = same;
}
}
Console.WriteLine(query[idx].Substring(0, max));
Console.WriteLine(query[idx].Substring(0, max).Length);
}
}
}
同样的问题为何问2遍?
public class RepeatSubstring {
/**
* @param args
* author:lao ban sha bi
*/
public static int FindMax(String S){
long startTime = System.currentTimeMillis();
int Length=S.length();
String A=null,B=null;
int MAX=0,max=1;
for(int a=0;a<Length;a++){
max=MAX+1;
for(int b=a+1;b<Length;b++){
if(b+max>Length) break;
A=S.substring(a, a+max);
B=S.substring(b, b+max);
if(A.equals(B))
{
if(MAX<max){
MAX=max;
}
b--;
max++;
}
}
}
long endTime = System.currentTimeMillis();
System.out.println((endTime-startTime)+"ms");
return MAX;
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner s = new Scanner(System.in);
String str = s.next();
System.out.println(FindMax(str));
}
}