标题:重复模式

作为 drd 的好朋友,技术男 atm 在 drd 生日时送给他一个超长字符串 S 。atm 要 drd 在其中找出一个最长的字符串 T ,使得 T 在 S 中至少出现了两次,而他想说的秘密就藏在 T 中。

由于字符串实在是太长了,drd 总是找不到合适的 T 。于是 drd 请你帮他找到这个 T 的长度。

【输入格式】

一行。一个字符串,即题目中说的S 。

【输出格式】

一行。一个整数,表示最长的 T 的长度。

【样例输入】

ababa

【样例输出】

3

「数据范围」

对于 30% 的数据,S长度 <= 100

对于 60% 的数据,S长度 <= 8000

对于 100% 的数据,S长度 <= 500000

资源约定:

峰值内存消耗 < 256M

CPU消耗 < 1000ms

他找重复的字符串就需要找相同开头

把每一种都取出来放在数组里面,把他们按照字典序排序,

数组上下基本上把相同开头的都匹配到了

直接for循环,把每一个相邻的字符串匹配一下 看看最长的重复字符串是多少,记录一下

大概就是这个意思吧,要不然数据规模太大了

import java.util.Arrays;
import java.util.Scanner; public class chongfumoshi2 {
public static void main(String[] args) {
// TODO 自动生成的方法存根
Scanner sc = new Scanner(System.in);
String input = sc.nextLine();
String[] subString = new String[input.length()];
for (int i = 0; i < subString.length; i++) {
subString[i] = input.substring(i);
}
Arrays.sort(subString);
// 排序后输出
for (int i = 0; i < subString.length; i++) {
System.out.println(subString[i]);
}
int maxLen = 0;
for (int i = 0; i < input.length() - 1; i++) {
int preLen = preLen(subString[i], subString[i + 1]);
if (preLen > maxLen) {
maxLen = preLen;
} }
System.out.println(maxLen);
} public static int preLen(String s1, String s2) {
int n = 0;
int minLen = s1.length() < s2.length() ? s1.length() : s2.length();
while (n < minLen && s1.charAt(n) == s2.charAt(n)) {
n++;
}
return n;
} }

最新文章

  1. Docker(一)
  2. Swift 和 C# 的语法比较
  3. 软件工程(FZU2015)赛季得分榜,第三回合
  4. 使用COALESCE时注意left join为null的情况
  5. String-------RegularHelper
  6. Android 通用流行框架大全
  7. boa服务器问题日志
  8. 支付宝Demo 报错
  9. phpcms v9 数据库分离部署
  10. Windows 7 Apache下计算机无法访问局域网网站的问题
  11. NSIS脚本:更改壁纸
  12. Vue组件模板形式实现对象数组数据循环为树形结构
  13. 仿微信未读RecyclerView平滑滚动定位效果
  14. 写自适应的textarea文本域
  15. SQL Server - GO
  16. java中random的几个方法的使用Math.random()和random().
  17. 51nod1462 树据结构(树链剖分+线段树)
  18. OpenCV学习:体验ImageWatch
  19. 【react 分页器】 基于react-virtualized组件的分页器
  20. 关于web后门权限防删的一个新思路

热门文章

  1. Coursera课程笔记----P4E.Capstone----Week 2&amp;3
  2. 高性能mysql第三版读书笔记3
  3. es6中 var 和 let的区别
  4. ASA failover配置(A/S)
  5. linux --文件目录的学习
  6. 正则表达式 [:graph:] 含义
  7. Web_php_include-攻防世界
  8. 轻量级熔断降级框架 alibaba sentinel 应用
  9. C#/VB.NET 将SVG图片添加到PDF、转换为PDF
  10. chrome &quot;items hidden by filters&quot;