Java数据结构及算法实例:朴素字符匹配 Brute Force
作者:junjie 发布时间:2022-01-10 15:03:40
标签:Java,数据结构,算法,朴素字符匹配,Brute,Force
/**
* 朴素字符串算法通过两层循环来寻找子串,
* 好像是一个包含模式的“模板”沿待查文本滑动。
* 算法的思想是:从主串S的第pos个字符起与模式串进行比较,
* 匹配不成功时,从主串S的第pos+1个字符重新与模式串进行比较。
* 如果主串S的长度是n,模式串长度是 m,那么Brute-Force的时间复杂度是o(m*n)。
* 最坏情况出现在模式串的子串频繁出现在主串S中。
* 虽然它的时间复杂度为o(m*n),但在一般情况下匹配时间为o(m+n),
* 因此在实际中它被大量使用。
* 该方法的优点是:算法简单明朗,便于实现记忆。
* 该方法的缺点是:进行了回溯,效率不高,而这些回溯都是没有必要的。
* 下面是该算法的Java代码,找到子串的话,返回子串在父串中第一次出现的位置,
* 找不到的话返回0.
*/
package al;
public class BruteForce {
public static void main(String[] args) {
String waitForMatch = "abbacbabcdabcbec";
String pattern = "abcbe";
BruteForce bruteForce = new BruteForce();
int index = bruteForce.getSubStringIndex(waitForMatch, pattern);
System.out.println("Matched index is "+index);
}
/**
* @author
* @param waitForMatch 主字符串
* @param pattern 模式字符串
* @return 第一次字符串匹配成功的位置
*/
public int getSubStringIndex(String waitForMatch, String pattern){
int stringLength = waitForMatch.length();
int patternLength = pattern.length();
// 从主串开始比较
for(int i=0; i<stringLength; i++) {
int k = i; // k指向主串下一个位置
for(int j=0; j<patternLength; j++) {
if(waitForMatch.charAt(k) != pattern.charAt(j)) {
break;
}else {
k++;// 指向主串下一个位置
if(j == patternLength-1) {
return i;
}
}
}
}
// 匹配不成功,返回0
return 0;
}
}


猜你喜欢
- 双重循环打印顶点在左上的直角三角形:public static void main(String[] args) { // TO
- 在系统的管理员有着实际的应用,对于一个数据库管理系统来说,数据库安全还是挺重要的,所以在存入到数据库的密码通常都是加密的。即使有着hack攻
- 概述:EventBus是一款针对Android优化的发布/订阅事件总线。主要功能是替代Intent,Handler,BroadCast在Fr
- 前言在上一篇学习SpringBoot中,整合了Mybatis、Druid和PageHelper并实现了多数据源的操作。本篇主要是介绍和使用目
- 1.scope 作用域Spring 管理的 bean 是根据 scope 来⽣成的,表示 bean 的作⽤域,共4种,默认值是 single
- 本文介绍了使用C#创建Windows服务的实例代码,分享给大家一、开发环境操作系统:Windows 10 X64开发环境:VS2015编程语
- 定义一个对象应该对其他对象保持最少的了解。问题由来类与类之间的关系越密切,耦合度越大,当一个类发生改变时,对另一个类的影响也越大。解决方案尽
- 文件存储文件存储方式不受类型限制,可以将一些数据直接以文件的形式保存在设备中,例如文本文件、PDF ,音频,图片等。存储类型复杂的数据时,通
- 本文实例为大家分享了JAVASE系统实现抽卡功能的具体代码,供大家参考,具体内容如下先看下文件结构使用到的知识点:看下Client类的实现:
- 1.概述MybatisPlus是国产的第三方插件, 它封装了许多常用的CURDapi,免去了我们写mapper.xml的重复劳动,这里介绍了
- 前言相信大家都知道Android滚动控件的实现方式有很多, 使用RecyclerView也比较简单. 做了一个简单的年龄滚动控件, 让我们来
- 引言前文中了解到AQS借助LockSupport.park和LockSupport.unpark完成线程的阻塞和唤醒,那么LockSuppo
- 什么是Spring BatchSpring Batch 是一个轻量级的、完善的批处理框架,旨在帮助企业建立健壮、高效的批处理应用。Sprin
- 1. RocketMQ Topic创建机制以下源码基于Rocket MQ 4.7.0RocketMQ Topic创建机制分为两种:一种自动创
- @Autowired注入依赖失败的问题1、现象描述在Spring Boot项目中使用@Autowired注解,程序启动时发现服务启动失败,提
- 最近在做一个需求:从其他系统的ftp目录下载存储图片url的文件,然后读取文件中的url地址,根据地址下载图片后按天压缩成一个包,平均一个地
- Annotation(注解)是JDK1.5及以后版本引入的。它可以用于创建文档,跟踪代码中的依赖性,甚至执行基本编译时检查。注解是以&
- Android studio开发工具中,如何如何删除Android项目,下面是在Android studio 1.5正式版删除Android
- 软件行业发展到今天,国际化问题一直都占据非常重要的位置,而且应该越来越被重视。对于开发人员而言,在编写程序之前,国际化问题是首先要考虑的一个
- 本文实例讲述了Java使用Random类生成随机数。分享给大家供大家参考,具体如下:一 代码import java.util.Random;