代码语言
.
CSharp
.
JS
Java
Asp.Net
C
MSSQL
PHP
Css
PLSQL
Python
Shell
EBS
ASP
Perl
ObjC
VB.Net
VBS
MYSQL
GO
Delphi
AS
DB2
Domino
Rails
ActionScript
Scala
代码分类
文件
系统
字符串
数据库
网络相关
图形/GUI
多媒体
算法
游戏
Jquery
Extjs
Android
HTML5
菜单
网页交互
WinForm
控件
企业应用
安全与加密
脚本/批处理
开放平台
其它
【
Java
】
求最长重复子串
作者:
风暴之灵_tlfu
/ 发布于
2013/10/23
/
496
public static void main(String[] arg) { String str = "ertyertyabcdabcdsdf464132132146464165479lhkjhnkjgibkjbjljdslfsajdlasdf4asdf5a7e123456789123456789"; int count = 2; List<String> maxLengthList = new ArrayList<String>(); maxLengthList = fetchMaxLeString(str, count, maxLengthList); System.out.println(maxLengthList); StringBuilder sbBuilder = new StringBuilder(); if (maxLengthList.isEmpty()) { System.out.println("无重复并且长度大于2的子串!"); } else { int maxLength = maxLengthList.get(0).length(); sbBuilder.append(maxLengthList.get(0)).append(","); for (int i = 1; i < maxLengthList.size(); i++) { if (maxLengthList.get(i).length() == maxLength) { sbBuilder.append(maxLengthList.get(i)).append(","); } } System.out.println("重复最长子串为:" + sbBuilder.toString().substring(0, sbBuilder.toString().length() - 1)); } } public static List<String> fetchMaxLeString(String str, int count, List<String> maxLengthList) { if (count > str.length() / 2 + 1) { return maxLengthList; } for (int i = 0; i < str.length() - count; i++) { List<String> strList = new ArrayList<String>(); String regex = str.substring(i, i + count) + "+?"; Pattern pattern = Pattern.compile(regex); Matcher matcher = pattern.matcher(str); while (matcher.find()) { strList.add(matcher.group()); } if (strList.size() > 1 && !maxLengthList.contains(str.substring(i, i + count))) { maxLengthList.add(str.substring(i, i + count)); } } count++; if (count > str.length()) { return maxLengthList; } fetchMaxLeString(str, count, maxLengthList); Collections.sort(maxLengthList, new Comparator<Object>() { @Override public int compare(Object o1, Object o2) { int length1 = o1.toString().length(); int length2 = o2.toString().length(); return length1 - length2 < 0 ? 1 : (length1 - length2 == 0 ? o1 .toString().compareTo(o2.toString()) : -1); } }); return maxLengthList; }
试试其它关键字
重复子串
同语言下
.
List 切割成几份 工具类
.
一行一行读取txt的内容
.
Java PDF转换成图片并输出给前台展示
.
java 多线程框架
.
double类型如果小数点后为零则显示整数否则保留两位小
.
将图片转换为Base64字符串公共类抽取
.
sqlParser 处理SQL(增删改查) 替换schema 用于多租户
.
JAVA 月份中的第几周处理 1-7属于第一周 依次类推 29-
.
java计算两个经纬度之间的距离
.
输入时间参数计算年龄
可能有用的
.
C#实现的html内容截取
.
List 切割成几份 工具类
.
SQL查询 多列合并成一行用逗号隔开
.
一行一行读取txt的内容
.
C#动态修改文件夹名称(FSO实现,不移动文件)
.
c# 移动文件或文件夹
.
c#图片添加水印
.
Java PDF转换成图片并输出给前台展示
.
网站后台修改图片尺寸代码
.
处理大图片在缩略图时的展示
风暴之灵_tlfu
贡献的其它代码
(
1
)
.
求最长重复子串
Copyright © 2004 - 2024 dezai.cn. All Rights Reserved
站长博客
粤ICP备13059550号-3