字符串搜索(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 ...
随机推荐
- 阿里云ecs自动创建快照教程
最近在一个博客联盟的微信群里面看到经常有朋友问阿里云的ecs服务器怎么设置自动创建快照,也不知道最近是怎么了,看到问这个问题的朋友有有四五个左右了,今天就特意到博客里来费大家分享设置自动创建快照的方法 ...
- 最新 竞网java校招面经 (含整理过的面试题大全)
从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.竞网等10家互联网公司的校招Offer,因为某些自身原因最终选择了竞网.6.7月主要是做系统复习.项目复盘.LeetCode ...
- CentOS 7 安装wordpress
1.安装php 要安装php 7,必须使用下面的命令在Centos7系统上安装并启用epel和remi存储库. 输入一下代码, yum install http://rpms.remirepo.net ...
- nginx 四个主要组成部分
1.Nginx 二进制可执行文件 由各模块源码编译出的一个文件 2.Nginx.conf 配置文件 控制nginx如何运行 3.access.log 访问日志 记录http请求信息 4.error.l ...
- [CF37D]Lesson Timetable_动态规划
Lesson Timetable 题目链接:https://www.codeforces.com/contest/37/problem/D 数据范围:略. 题解: 根本就没想到可以动态规划. 首先从前 ...
- [转帖]Linux内核剖析(一)Linux的历史
Linux内核剖析(一)Linux的历史 https://www.cnblogs.com/alantu2018/p/8991158.html Unix操作系统 Unix的由来 汤普逊和里奇最早是在贝尔 ...
- django授权-01--oauth2
oauth2的提供商:认证服务器 oauth2的消费者:目标服务器 如果目标服务器与认证服务器不一样的话,相当于目标服务器向认证服务器获取用户的信息 如果目标服务器和认证服务器一样的话,相当于用户获取 ...
- redis事务、并发及应用场景
目录 事务概念 事务命令 乐观锁 悲观锁 并发控制及过期时间 队列 队列防丢失 阻塞队列 时间区间控制 持久化 RDB AOF 命令追加 文件写入.同步 RDB.AOF优缺点 RDB优缺 AOF优缺 ...
- 模块 os 和 sys
目录 os 模块 sys 模块 os 模块 os 模块是与操作系统交互的一个接口 方法 详解 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir(&quo ...
- 解决GitHub下载慢问题,不用修改HOSTS文件
写这篇文章缘由是我用的一款Github上的软件软件版本更新,想去Github上下载新的版本,结果下载速度居然只有几k,还老是下载失败,然后去修改HOSTS文件(我看文章基本都是叫修改这个),修改完成后 ...