Java实现字符串匹配的示例代码
作者:CoderDreams 时间:2023-04-17 05:24:35
java实现字符串匹配
暴力匹配
/**
* 暴力匹配
*
* @param str1 需要找的总字符串
* @param str2 需要找到的字符串
* @return 找到的字符串的下标
*/
private static int violence(String str1, String str2) {
char[] s1 = str1.toCharArray();
char[] s2 = str2.toCharArray();
int s1Len = s1.length;
int s2Len = s2.length;
// 指针,分别指向两个字符串
int i = 0;
int j = 0;
// 保证匹配时不越界
while (i < s1Len && j < s2Len) {
// 第一个字符匹配上了
if (s1[i] == s2[j]) {
++i;
++j;
} else {
i -= (j - 1);
j = 0;
}
}
// 判断是否成功
if (j == s2Len) {
return i - j;
} else {
return -1;
}
KMP算法
/**
* KMP算法
*
* @param str1 源字符串
* @param str2 子串
* @param next 匹配值表
* @return 对应下标,没有为-1
*/
private static int kmp(String str1, String str2, int[] next) {
for (int i = 0, j = 0; i < str1.length(); ++i) {
while (j > 0 && str1.charAt(i) != str2.charAt(j)) {
j = next[j - 1];
}
if (str1.charAt(i) == str2.charAt(j)) {
j++;
if (j == str2.length()) {
return i - j + 1;
}
return -1;
}
* @return dest的部分匹配表
private static int[] getkmpNext(String dest) {
int length = dest.length();
int[] next = new int[length];
next[0] = 0;
for (int i = 1, j = 0; i < length; i++) {
while (j > 0 && dest.charAt(i) != dest.charAt(j)) {
if (dest.charAt(i) == dest.charAt(j)) {
next[i] = j;
return next;
来源:https://www.cnblogs.com/coderDreams/p/16188698.html
标签:java,字符串,匹配
0
投稿
猜你喜欢
Unity3D实现人物移动示例
2022-08-15 21:51:58
spring的@Transactional注解用法解读
2021-10-08 23:48:43
如何使用Spring AOP预处理Controller的参数
2022-09-11 10:01:56
mybatis-plus 返回部分字段的解决方式
2023-03-25 14:45:04
spring mvc中的@ModelAttribute注解示例介绍
2023-10-15 07:07:06
android自定义进度条渐变色View的实例代码
2023-07-01 20:58:57
Java实现一个简单的定时器代码解析
2021-11-24 20:25:38
C# 字符串与unicode互相转换实战案例
2023-12-23 09:29:54
C++实现String类的方法详解
2023-04-27 08:49:27
java 中sendredirect()和forward()方法的区别
2021-11-07 18:39:28
Spring Security 强制退出指定用户的方法
2022-10-04 18:13:04
Android RecyclerView item选中放大被遮挡问题详解
2023-04-11 17:58:31
关于synchronized有趣的同步问题
2021-11-03 05:46:55
C#实现简单聊天程序的方法
2022-01-02 22:31:20
c# 实现RSA非对称加密算法
2021-10-15 10:54:06
基于java文件上传-原始的Servlet方式
2021-10-17 13:26:25
SpringCloud Config统一配置中心问题分析解决与客户端动态刷新实现
2023-08-17 17:19:48
Android实现环形进度条的实例
2023-01-11 17:39:22
java 基础之JavaBean属性命名规范问题
2022-10-09 05:44:22
Seata AT模式如何实现行锁详解
2022-11-18 23:43:34