栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

5.6 实现strStr() (串)——【LeetCode】

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

5.6 实现strStr() (串)——【LeetCode】

package com.string.java;

public class six {

	//方法一:
	//基于滑动窗口的算法
	public int strStr(String haystack, String needle) {
		int m = needle.length();
		// 当 needle 是空字符串时我们应当返回 0
		if(m == 0) {
			return 0;
		}
		int n = haystack.length();
		if(n < m) {
			return -1;
		}
		int i = 0;
		int j = 0;
		while(i < n - m + 1) {
			//找到首字母相等
			while(i < n && haystack.charAt(i) != needle.charAt(j)) {
				i++;
			}
			if(i == n) {//没有找到
				return -1;
			}
			//执行到此处,说明存在相等字符,继续遍历后续字符,判断是否相等
			i++;
			j++;
			while(i < n && j < m && haystack.charAt(i) == needle.charAt(j)) {
				i++;
				j++;
			}
			if(j == m) {//说明找到
				return i - j;//即i-m
			}else {//未找到 此处看到匹配不成功的话这里只是将needle向右移动了一下 重新匹配
				i -= j-1;
				j = 0;
			}
		}
		return -1;
	}

	//方法二:KMP
	public int strStr1(String haystack, String needle) {
		if(needle.length() == 0) {
			return 0;
		}
		int[] next = new int[needle.length()];
		getNext(next, needle);//获取needle的部分匹配值表
		
		for (int i = 0, j = 0; i < haystack.length(); i++) {
            while (j > 0 && needle.charAt(j) != haystack.charAt(i)) {
            	j = next[j - 1];//更新j值
            }
            if (needle.charAt(j) == haystack.charAt(i)) {
            	j++;
            }
            if (j == needle.length()) {
            	return i - needle.length() + 1;
            }
        }
		return -1;
	}
	
	//获取到一个字符串(子串) 的部分匹配值表
	private void getNext(int[] next, String dest) {

		next[0] = 0; //如果字符串是长度为1 部分匹配值就是0
		for(int i = 1,j = 0; i < dest.length();i++) {
			//当dest.charAt(i) != dest.charAt(j) ,我们需要从next[j-1]获取新的j
			//直到我们发现 有  dest.charAt(i) == dest.charAt(j)成立才退出
			//这是kmp算法的核心点
			while(j > 0 && dest.charAt(i) != dest.charAt(j)) {
				j = next[j-1];
			}
			//当dest.charAt(i) == dest.charAt(j) 满足时,部分匹配值就是+1
			if(dest.charAt(i) == dest.charAt(j)) {
				j++;
			}
			next[i] = j;
		}
	}
}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/727565.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号