LeetCode 28题:找出字符串中第一个匹配项的下标
题目
给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标(下标从 0 开始)。如果 needle 不是 haystack 的一部分,则返回 -1 。
示例 1:
输入:haystack = "sadbutsad", needle = "sad" 输出:0 解释:"sad" 在下标 0 和 6 处匹配。 第一个匹配项的下标是 0 ,所以返回 0 。
示例 2:
输入:haystack = "leetcode", needle = "leeto" 输出:-1 解释:"leeto" 没有在 "leetcode" 中出现,所以返回 -1 。
提示:
1 <= haystack.length, needle.length <= 104haystack和needle仅由小写英文字符组成
Python
看到这道题的一瞬间,我就想到了Python中的find()函数,所以很快就写好了:
class Solution(object):def strStr(self, haystack, needle):return haystack.find(needle) A=Solution()
haystack ="sadbutsad"
needle ="sad"
print(A.strStr(haystack,needle))
这样虽然简单,但数据不是很好:
C语言
#include<stdio.h>
#include<stdlib.h>
#include<string.h>int strStr(char * haystack, char * needle);int main()
{char* haystack ="sadbutsad";char* needle ="sad";printf("%d",strStr(haystack,needle));return 0;
}//主要函数
int strStr(char * haystack, char * needle)
{int len1=strlen(haystack),len2=strlen(needle);for(int i=0;i<=len1-len2;i++){if(haystack[i]==needle[0]){if(len2==1)return i;int j=1;for(;j<len2;j++){if(haystack[j+i]!=needle[j]){break;} } if(j==len2)return i;}}return -1;
}
但结果不好:
之后,我看了KMP算法,确实巧妙。

我写的C语言代码是在每次 haystack 数组与needle数组比较元素不匹配后,在haystack上移动一位来进行重新比较,进而寻找正确位置。
而KMP算法则是每次移动若干位(根据字符串),进而缩短了时间。
KMP算法代码:
int strStr(char* haystack, char* needle) {int n = strlen(haystack), m = strlen(needle);if (m == 0) {return 0;}int pi[m];pi[0] = 0;for (int i = 1, j = 0; i < m; i++) {while (j > 0 && needle[i] != needle[j]) {j = pi[j - 1];}if (needle[i] == needle[j]) {j++;}pi[i] = j;}for (int i = 0, j = 0; i < n; i++) {while (j > 0 && haystack[i] != needle[j]) {j = pi[j - 1];}if (haystack[i] == needle[j]) {j++;}if (j == m) {return i - m + 1;}}return -1;
}/*
作者:力扣官方题解
链接:https://leetcode.cn/problems/find-the-index-of-the-first-occurrence-in-a-string/solutions/732236/shi-xian-strstr-by-leetcode-solution-ds6y/
来源:力扣(LeetCode)
*/
相关文章:
LeetCode 28题:找出字符串中第一个匹配项的下标
题目 给你两个字符串 haystack 和 needle ,请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标(下标从 0 开始)。如果 needle 不是 haystack 的一部分,则返回 -1 。 示例 1: 输入:haystac…...
flink+kafka+doris+springboot集成例子
目录 一、例子说明 1.1、概述 1.1、所需环境 1.2、执行流程 二、部署环境 2.1、中间件部署 2.1.1部署kakfa 2.1.1.1 上传解压kafka安装包 2.1.1.2 修改zookeeper.properties 2.1.1.3 修改server.properties 2.1.1.3 启动kafka 2.1.2、部署flink 2.1.2.1 上传解压f…...
ARM裸机-14(S5PV210的时钟系统)
1、时钟系统 1.1、什么是时钟 时钟是同步工作系统的同步节拍 1.2、SoC为什么需要时钟 Soc内部有很多器件,例如CPU、串口、DRAM控制制器、GPIO等内部外设,这些东西要彼此协同工作,需要一个同步的时钟系统来指挥。这个就是我们SoC的时钟系统。…...
Milvus Cloud凭借AI原生,可视化优势荣登全球向量数据库性能排行榜VectorDBBench.com 榜首
在当今的大数据时代,随着人工智能技术的快速发展,向量数据库作为处理大规模数据的关键工具,其性能和效率越来越受到关注。最近,全球向量数据库性能排行榜 VectorDBBench.com 公布了一份最新的评估报告,引人瞩目的是,成立不到一年的新兴公司 Milvus Cloud 凭借其 AI 原生和…...
测试岗?从功能测试进阶自动化测试开发,测试之路不迷茫...
目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 测试新人在想什么…...
算法与数据结构(五)--树【1】树与二叉树是什么
一.树的定义 树是一个具有层次结构的集合,是由一个有限集和集合上定义的一种层次结构关系构成的。不同于线性表,树并不是线性的,而是有分支的。 树(Tree)是n(n>0)个结点的有限集。 若n0&…...
打开的idea项目maven不生效
方法一:CtrlshiftA(或者help---->find action), 输入maven, 点击add maven projects,选择本项目中的pom.xml配置文件,等待加载........ 方法二:view->tools windows->mave…...
kvm+qemu+libvirt管理虚机
virt-manager 图形化创建虚拟机 #virt-manager纳管远程kvm虚拟机 # 可以指定kvm虚机的ssh端口和virt-manager所在主机的私钥 virt-manager -c qemussh://root10.197.115.17:5555/system?keyfileid_rsa --no-fork # 如果你生成的ssh-key 的名称是 test-key,在/home/ssh-key/ 目…...
电气防火限流式保护器在汽车充电桩使用上的作用
【摘要】 随着电动汽车行业的不断发展,电动汽车充电设施的使用会变得越来越频繁和广泛。根据中汽协数据显示,2022年上半年,我国新能源汽车产销分别完成266.1万辆和260万辆,同比均增长1.2倍,市场渗透率达21.6%。因此,电动汽车的安全…...
VBA技术资料MF38:VBA_在Excel中隐藏公式
【分享成果,随喜正能量】佛祖也无能为力的四件事:第一,因果不可改,自因自果,别人是代替不了的;第二,智慧不可赐,任何人要开智慧,离不开自身的磨练;第三&#…...
Gson:解析JSON为复杂对象:TypeToken
需求 通过Gson,将JSON字符串,解析为复杂类型。 比如,解析成如下类型: Map<String, List<Bean>> 依赖(Gson) <dependency><groupId>com.google.code.gson</groupId><art…...
伪彩色处理及算法
伪色彩(false color)是指将真实世界的中无法被肉眼观察到的色彩通过计算机或其他技术转换为可见光,从而使人们能够看到这些原本无法看到的色彩。这种技术被广泛应用于军事、医学、科研等领域。 在医学领域,伪色彩技术被用于医学影像诊断。例如,通过将不同灰度的图像映射到…...
Gradle-02:问题Plugin with id ‘maven‘ not found
1. 背景 在一次使用 Gradle 构建自己项目,完事,需要上传到本地 Maven 仓库,因为事先并不清楚 apply plugin: maven 插件已经被 Gradle 移除,找了一圈,才找到解决方案。 2. 原因 apply plugin: maven def localRepo f…...
jupyter lab环境配置
1.jupyterlab 使用虚拟环境 conda install ipykernelpython -m ipykernel install --user --name tf --display-name "tf" #例:环境名称tf2. jupyter lab kernel管理 show kernel list jupyter kernelspec listremove kernel jupyter kernelspec re…...
Unity Sort Group(排序组)
** Unity 中的Sort Group组组件允许让Sprite Renderer(精灵渲染器)重新决定渲染顺序. ** 作为组件存在 组件内容: Unity 使用Sort Group 组件的Sort layer 和Order in layer的值来确定排序组在渲染队列内相对与场景内其他排序组和游戏对象的优先级。 属性功能So…...
基于总线加锁和缓存锁(CPU实现原子操作的两种方式)
总线锁 总线锁就是使用处理器提供的一个LOCK#信号,当一个处理器在总线上输出此信号时,其他处理器的请求将被阻塞住,那么该处理器可以独占共享内存。 CPU和内存之间的通信被锁!! 如果多个处理器同时对共享变量进行读写…...
MybatisPlus存在 sql 注入漏洞(CVE-2023-25330)解决办法
首先我们了解下这个漏洞是什么? MyBatis-Plus TenantPlugin 是 MyBatis-Plus 的一个为多租户场景而设计的插件,可以在 SQL 中自动添加租户 ID 来实现数据隔离功能。 MyBatis-Plus TenantPlugin 3.5.3.1及之前版本由于 TenantHandler#getTenantId 方法在…...
【java】使用maven完成一个servlet项目
一、创建项目 创建一个maven项目 maven是一个管理java项目的工具,根据maven的pom.xml可以引入各种依赖,插件。 步骤 打开idea,点击新建项目 点击创建项目,项目创建就完成了 进入时会自动打开pom.xml文件。 pom是项目的配置文件…...
前端Vue入门-day07-Vuex入门
(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹) 目录 自定义创建项目 vuex概述 构建 vuex [多组件数据共享] 环境 创建一个空仓库 state 状态 1. 提供数据&…...
2023再谈前端状态管理
目录 什么是状态管理? 状态 常见模式 要解决的问题 心智模型 React Context Context 的问题 优点 缺点 React 外部状态管理库 概览 Class 时代 Redux 单向数据流 三大原则 如何处理异步 如何处理数据间联动 优点 缺点 Dva icestore Mobx 设…...
BEYOND REALITY Z-Image应用案例:电商人像、社交配图一键生成攻略
BEYOND REALITY Z-Image应用案例:电商人像、社交配图一键生成攻略 1. 为什么选择BEYOND REALITY Z-Image 在电商和社交媒体领域,高质量的人像图片需求量大但制作成本高。传统摄影需要模特、化妆师、摄影师和后期团队配合,单张图片成本可能高…...
使用LaTeX撰写基于YOLOv12的学术论文:图表与算法排版最佳实践
使用LaTeX撰写基于YOLOv12的学术论文:图表与算法排版最佳实践 写论文,尤其是涉及复杂模型和大量实验的计算机视觉方向论文,最头疼的往往不是实验本身,而是如何把那些漂亮的图表、复杂的算法和严谨的参考文献,优雅地“…...
SDMatte环境部署避坑指南:从Python安装到模型推理全流程
SDMatte环境部署避坑指南:从Python安装到模型推理全流程 1. 前言:为什么要用SDMatte? 如果你正在寻找一个强大的图像抠图工具,SDMatte可能是你的理想选择。这个基于深度学习的模型能够精准地从复杂背景中分离出前景物体…...
达摩院AI春联生成器实测:输入两字,收获一副有文化的原创春联
达摩院AI春联生成器实测:输入两字,收获一副有文化的原创春联 春节将至,家家户户都开始张罗贴春联。但你是否遇到过这样的困扰:想写一副既有文化底蕴又独具特色的春联,却苦于词穷?传统的"福星高照&quo…...
StructBERT情感分类模型在职场评论分析中的应用
StructBERT情感分类模型在职场评论分析中的应用 1. 引言 "公司食堂的饭菜越来越差了,每天排队还要半小时","这次晋升机制很公平,大家都有机会","团队氛围很好,但加班实在太多了"...这…...
海思SS524/SS522系列SDK编译实战:从零构建DVR开发环境
1. 海思SS524/SS522芯片与DVR开发入门 第一次接触海思SS524/SS522系列芯片时,我被它强大的视频处理能力震撼到了。这颗芯片简直就是为DVR产品量身定制的,特别是当你需要处理多路高清视频流时,它的优势就更加明显。SS524和SS522虽然型号不同&a…...
OpenClaw高阶玩法:Qwen3-4B模型微调适配专属自动化流程
OpenClaw高阶玩法:Qwen3-4B模型微调适配专属自动化流程 1. 为什么需要定制化模型? 去年夏天,我尝试用OpenClaw自动化处理一批专业文献时遇到了瓶颈。当AI试图理解"CRISPR-Cas9基因编辑技术"这类术语时,标准模型要么要…...
OpenClaw夜间任务方案:Phi-3-mini-128k-instruct实现24小时监控与报警
OpenClaw夜间任务方案:Phi-3-mini-128k-instruct实现24小时监控与报警 1. 为什么需要夜间自动化监控 凌晨三点被报警电话吵醒的经历,相信每个运维过个人项目的开发者都深有体会。传统方案要么依赖付费的SaaS监控服务,要么需要自己写复杂的c…...
程序员必备:10个免费IT电子书网站实测推荐(附优缺点对比)
程序员必备:10个免费IT电子书资源站深度评测与实战指南 在技术迭代飞快的时代,持续学习是程序员保持竞争力的核心。优质电子书资源站如同数字时代的图书馆,但面对海量选择,如何高效筛选真正实用的平台?本文基于三个月实…...
双模型混搭方案:OpenClaw同时接入Phi-3-mini-128k-instruct与Qwen1.5
双模型混搭方案:OpenClaw同时接入Phi-3-mini-128k-instruct与Qwen1.5 1. 为什么需要双模型混搭? 在我的日常开发工作中,经常遇到两种截然不同的需求场景:一种是需要处理超长技术文档的阅读理解与摘要生成,另一种是快…...


