字符串搜索(strStr)--- java版
这里来学习一下从一个源字符串中搜索指定的字符串,有些啰嗦,直接看最终的效果:
实际上JAVA SDK中相当于String.indexOf()方法,上面的用例改用JAVA SDK来实现看一下:

编译运行:

结果一模一样~
而首先先用JAVA语言去实现这个算法,如何实现呢,下面先来捋一下思路:

如果想从上图中搜"cde"这个字符串的位置如何搞呢?假设source代表源字符串、target代表待搜索的字符串:
1、搜寻的总次数max=source.length() - target.length();
2、每次搜寻时,拿target中的字符跟source的起始位置进行匹对,如果一个都不相等,则此次循环结果,往下继续循环;如果第一个相等了,则再拿target的第二个元素进行对比,以此循环,只要有一个没匹对上,则当前循环结束;其当target的所有元素都匹配完了则将当前循环的位置返回出来。
下面直接上代码:

下面来分析一下流程,以
这个用例来进行分析:

其中参数:source="abcde"、target="cde"
①、int max = 5 - 3 = 2;也就是总搜寻的次数,"c"以后由于已经小于target的长度了,所以再循环就没意义了。
②、开始对源字符串进行循环一一进行对比:
i=0,i <= 2,开始Loop1:
a、int matched_count = 0;用来进行对匹配的数量进行累加。
b、接着用target一个个字符跟source进行对比,实际就是一个循环:
1、for(; 0 < 3 && source.charAt(0) == target.charAt(0);0++) = for(; 0 < 3 && 'a' == 'c';0++),很显然循环条件不满足,所以直接退出该循环。
c、由于matched_count【0】 == target.length()【3】条件不满足,所以继续循环。
i++ = 1;
i=1,i <= 2,开始Loop2:
a、int matched_count = 0;用来进行对匹配的数量进行累加。
b、接着用target一个个字符跟source进行对比,实际就是一个循环:
1、for(; 0 < 3 && source.charAt(1) == target.charAt(0);0++) = for(; 0 < 3 && 'b' == 'c';0++),很显然循环条件不满足,所以直接退出该循环。
c、由于matched_count【0】 == target.length()【3】条件不满足,所以继续循环。
i++ = 2;
i=2,i <= 2,开始Loop3:
a、int matched_count = 0;用来进行对匹配的数量进行累加。
b、接着用target一个个字符跟source进行对比,实际就是一个循环:
1、for(; 0 < 3 && source.charAt(2) == target.charAt(0);0++) = for(; 0 < 3 && 'c' == 'c';0++),条件满足,则matched_count++=1,继续对target下一个元素进行匹配;
2、for(; 1 < 3 && source.charAt(3) == target.charAt(1);1++) = for(; 0 < 3 && 'd' == 'd';1++),条件满足,则matched_count++=2,继续对target下一个元素进行匹配;
3、for(; 2 < 3 && source.charAt(4) == target.charAt(2);2++) = for(; 2 < 3 && 'e' == 'e';2++),条件满足,则matched_count++=3,继续对target下一个元素进行匹配;
4、for(; 3 < 3 && source.charAt(5) == target.charAt(3);3++)明显条件不满足,所以匹配过程结束。
c、由于matched_count【3】 == target.length()【3】条件满足,则证明刚好能匹配上,将当前位置i=2返回。
③、如果没有搜寻到则返回-1。
下面来看一下这种算法的时间复杂度:

所以比较明显O(m * n)是它的时间复杂度,也就是随着source和target字串的长度的变化用的时间也会相应进行便化。
字符串搜索(strStr)--- java版的更多相关文章
- 用递归调用实现字符串反转(java版)
写一个函数,输入int型,返回整数逆序后的字符串.如:输入123,返回“321”. 要求必须用递归,不能用全局变量,输入必须是一个参数,必须返回字符串. public static String re ...
- 基于opencv将视频转化为字符串Java版
基于opencv将视频转化为字符串Java版 opencv java 先上一个效果图吧 首先,弄清一下原理 我们要将视频转化为字符画,那么就需要获取画面的每一帧,也就是每一张图片,然后将图片进行转化 ...
- 热门搜索词获取java版
日常生活中经常会有这样的需求,就是网站上.app上需要展示近期热搜的一些词汇,其实常用的做法当然是自己写爬虫去爬,不过这种办法是在太麻烦了,为了节省时间,可以调用一些接口来实现,比如常用的聚合数据,小 ...
- 第六篇 :微信公众平台开发实战Java版之如何自定义微信公众号菜单
我们来了解一下 自定义菜单创建接口: http请求方式:POST(请使用https协议) https://api.weixin.qq.com/cgi-bin/menu/create?access_to ...
- python实现文章或博客的自动摘要(附java版开源项目)
python实现文章或博客的自动摘要(附java版开源项目) 写博客的时候,都习惯给文章加入一个简介.现在可以自动完成了!TF-IDF与余弦相似性的应用(三):自动摘要 - 阮一峰的网络日志http: ...
- [第二届构建之法论坛] 预培训文档(Java版)
本博客是第二届构建之法论坛暨软件工程培训活动预培训文档中[适用于结对编程部分的Java版本],需要实验者有一部分Java基础. 目录 Part0.背景 Part1.配置环境 配置JDK Linux 平 ...
- 如何做系列(4)-微博URL短网址生成算法原理(java版、php版实现实例)
短网址(Short URL),顾名思义就是在形式上比较短的网址.通常用的是asp或者php转向,在Web 2.0的今天,不得不说,这是一个潮流.目前已经有许多类似服务,借助短网址您可以用简短的网址替代 ...
- JAVA版StarDict星际译王简单实现
由胡正开发的星际译王是Linux平台上很强大的一个开源的翻译软件(也有Windows版本的)支持多种词库.多种语言版本.尤其词库设计比较合理.之前看到一篇博文<星际译王词库应用-自制英汉词典&g ...
- java版gRPC实战之三:服务端流
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- java版gRPC实战之六:客户端动态获取服务端地址
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
随机推荐
- spacemacs:emacs和vim结合,大杀器。vim党转emacs
结合本人基础,做下述结论.不一定准确. 基础: 1. vim操作和高级操作,熟悉.使用的spf13-vim. 2. emacs以前学过,但是按键太累,相比vim简直难受. 3. emacs命令 ...
- UIPath工具取得某个路径下的文件夹的名称
UIPath工具取得某个路径下的文件夹的名称 处理的流程如下图 [Edit Code]按钮押下之后写入代码如下 Dim dir As New DirectoryInfo("C:\Users\ ...
- python线程事件Event(30)
在python项目开发中,线程thread使用是比较常见的,在前面的文章中我们介绍了 python线程的创建 以及 线程互斥锁 ,今天还要额外介绍一个与线程相关的内容 – 事件Event. 一.pyt ...
- [转帖]PostgreSQL 昨天,今天和明天
PostgreSQL 昨天,今天和明天 http://www.postgres.cn/v2/news/viewone/1/52 原作者:何伟平(laser) 创作时间:2005-01-15 11:44 ...
- 深入理解 Css3 的 clip-path
clip-path CSS 属性可以创建一个只有元素的部分区域可以显示的剪切区域.区域内的部分显示,区域外的隐藏.clip-path属性代替了现在已经弃用的剪切 clip属性.clip-path的属性 ...
- 如何安装Oracle--新手安装Oracle教程
1. 将win32_11gR2_database_1of2.zip与win32_11gR2_database_1of2.zip 解压到当前目录 PS:选中两个压缩包后右键解压到当前文件夹:必须同时解压 ...
- java用POI导出Excel
架构SSM + Maven 一.添加依赖: <dependency> <groupId>org.apache.poi</groupId> <artifactI ...
- 用js实现菜单的下拉列表,实用又简单
下拉列表本可以用<select>配合<option>来写,方便得很.但是在前端中,好用的东西都有兼容,为了避免出现兼容性的问题,下拉列表用js写再合适不行了. <body ...
- MongoDB增删改
一.数据库操作 显示现有的数据库,命令:show dbs 或者 databases; 示当前使用的数据库,命令:db 切换当前使用的数据库,命令:use 数据库名称 删除数据库,命令:db.dropD ...
- linux中的内核级防火墙(SELINUX)
SElinux是基于内核开发出来的一种安全机制,被称之为内核级加强型防火墙,有力的提升了系统的安全性. SElinux的作用分为两方面:1.在服务上面加上标签: 2.在功能上面限制功能 在linux系 ...