代码随想录 28. 找出字符串中第一个匹配项的下标(KMP算法)

题目:


代码(首刷自解 暴力 2024年1月18日):

class Solution {
public:
    int strStr(string haystack, string needle) {
        int n = haystack.size();
        int nstr = 0;
        for (int i = 0; i < n; ++i) {
            if (haystack[i] == needle[0]) {
                int hstr = i;
                while (haystack[hstr] == needle[nstr] && nstr < needle.size()) {
                    if (nstr == needle.size() - 1) {
                        return i;
                    }
                    ++hstr;
                    ++nstr;
                } 
                nstr = 0;
            }
        }
        return -1;
    }
};

代码(首刷看解析 KMP算法 2024年1月18日):

class Solution {
public:
    void getNext(string& str, vector<int>& next) {
        /*  作用:构建str字符串的前缀表 */
        int j = 0;
        for (int i = 1; i < str.size(); ++i) {
            while (j > 0 && str[i] != str[j]) {
                j = next[j - 1];
            }
            if (str[i] == str[j]) {
                ++j;
            }
            next[i] = j;
        }
        for (int i = str.size() - 2; i >= 0; --i) {
            next[i + 1] = next[i];
        }
        next[0] = -1;
    }   

    int strStr(string haystack, string needle) {
        int n = needle.size();
        if(n == 0) return 0;
        vector<int> next(n);
        getNext(needle,next);

        int j = 0;
        for (int i = 0; i < haystack.size(); ++i) {
            while (j > 0 && haystack[i] != needle[j]) {
                j = next[j];
            }
            if (haystack[i] == needle[j]) {
                ++j;
            }
            if (j == n) return i - j + 1;
        }
        return -1;
    }
};

        构建前缀表的具体实现我选择了构建完后整体 右移 1 位,因为我认为这样比较好理解,当整体右移一位时,当主串和模式串不匹配,next[index]就会是上一个匹配点的位置。

        PS:搞懂了KMP+写出无BUG代码花了整整3小时

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/330875.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring boot项目java bean和xml互转

Spring boot项目实现java bean和xml互转 项目场景&#xff1a;互转方法使用jackson进行互转使用jaxws进行xml与bean的互转 搞定收工&#xff01; 项目场景&#xff1a; 工作中需要给下游第三方收费系统做数据挡板&#xff0c;由于下游系统使用的是soap webservice,里面涉及各种…

Django笔记(一):环境部署

目录 Python虚拟环境 安装virtualenv 创建环境 激活环境 关闭&#xff1a; 安装Django VSCode配置 Python插件 Django插件 解释器选择 Django部署 创建项目 创建app 创建模板 编写视图 编写路由 启动服务器 访问 Python虚拟环境 安装virtualenv pip i…

低代码助力制造业数智转型,激发创新力迎接工业 4.0

随着科技的不断进步&#xff0c;我们迈入了一个崭新的工业时代——工业4.0。这场工业革命不仅颠覆了制造业的传统形象&#xff0c;还为全球生产方式带来了前所未有的变革。 在这一过程中&#xff0c;制造业数字化转型逐渐成为主旋律&#xff0c;而低代码技术在这其中发挥着重要…

网上订货管理系统功能列表|企业手机订单管理软件

网上订货管理系统功能列表|企业手机订单管理软件 后台功能列表 &#xff08;后台支持手机版本 订货APP,管理订单的APP&#xff09; 后台登陆 输入账号密码登录企业订货管理软件系统 后台首页 显示近日,月,年订单统计&#xff0c;和收款欠款等统计。 订单模块 新建订单 &am…

Java:选择哪个Java IDE好?

Java&#xff1a;选择哪个Java IDE好? 在开始前我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「java的资料从专业入门到高级教程」&#xff0c; 点个关注在评论区回复“888”之后私信回复“888”&#xff0c;全部无偿共享给大家&#xff01;&#xff01;&…

空气制水机市场调研:预计2029年将达到5.2亿美元

空气制水机&#xff0c;是一种通过高效过滤空气中的水分子冷凝成为液态水&#xff0c;再通过一系列净化处理方法生产出高品质饮用水的设备。也就是说&#xff0c;它靠空气温度和湿度驱动取水&#xff0c;经过几层空气过滤和水路过滤&#xff0c;制造出安全健康的直饮水&#xf…

电力能源三维可视化合集 | 图扑数字孪生

电力能源是现代社会发展和运行的基石&#xff0c;渗透于工业、商业、农业、家庭生活等方方面面&#xff0c;它为经济、生活质量、环境保护和社会发展提供了巨大的机会和潜力。图扑软件应用自研 HT for Web 强大的渲染引擎&#xff0c;助力现代化的电力能源数字孪生场景&#xf…

RHCE9学习指南 第22章 用rpm管理软件

rpm全称是redhat package manager&#xff0c;后来改成rpm package manager&#xff0c;这是根据源码包编译出来的包。先从光盘中拷贝一个包&#xff0c;并看他是如何命名的。 先挂载光盘&#xff0c;然后拷贝vsftpd这个包&#xff0c;命令如下。 [rootserver ~]# mount /dev/…

如何绘制出图像的色素分布直方图

效果 如图&#xff0c;可以展示出我们的图像的颜色分布直方图,表明的图像的亮和暗 实现可视化色素分布直方图方法 这里我们对我们的灰色图片和彩色图片进行了直方图显示 import cv2 import matplotlib.pyplot as plt image cv2.imread("test.jpg") # 彩色图片->…

【leetcode 2171. 拿出最少数目的魔法豆】没有数学,全是思路

2171. 拿出最少数目的魔法豆 题目描述 给定一个 正整数 数组 beans &#xff0c;其中每个整数表示一个袋子里装的魔法豆的数目。 请你从每个袋子中 拿出 一些豆子&#xff08;也可以 不拿出&#xff09;&#xff0c;使得剩下的 非空 袋子中&#xff08;即 至少还有一颗 魔法豆…

鼠害监测站的意义是什么

鼠害监测站是专门用于监测鼠害发生情况、种群结构和危害程度的设施。这些站点通常设立在农田、森林、草原等鼠害易发区域&#xff0c;通过定期调查和监测&#xff0c;收集鼠害相关信息&#xff0c;为防治工作提供科学依据。 TH-SH1 鼠害监测站的意义 保障农业生产&#xff1a;…

精品基于Uniapp+springboot美食菜谱类管理系统APP

《[含文档PPT源码等]精品基于Uniappspringboot美食类管理系统APP》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功&#xff01; 软件开发环境及开发工具&#xff1a; 开发语言&#xff1a;Java 后台框架&#xff1a;springboot、ssm 安…

SpringBoot中整合MybatisPlus快速实现Mysql增删改查和条件构造器

场景 Mybatis-Plus(简称MP)是一个Mybatis的增强工具&#xff0c;只是在Mybatis的基础上做了增强却不做改变&#xff0c;MyBatis-Plus支持所有Mybatis原生的特性&#xff0c; 所以引入Mybatis-Plus不会对现有的Mybatis构架产生任何影响。MyBatis 增强工具包&#xff0c;简化 C…

掌握退款与测评自养号技术,在亚马逊、沃尔玛上轻松做卖家

今天&#xff0c;我想与大家分享在亚马逊、沃尔玛退款自养号中的一些经验。众所周知&#xff0c;自养号的环境是至关重要的&#xff0c;它涉及到系统的纯净度、下单所用的信用卡以及许多其他细节。一个良好的养号环境能够确保账号的安全与稳定&#xff0c;进而提高退款成功率。…

2023年暴涨130%后,嘉年华游轮股价2024年还会继续暴涨吗?

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 2023年对嘉年华游轮来说的标志性的一年 2023年&#xff0c;嘉年华游轮(CCL)的业务不但实现了全面复苏&#xff0c;而且其股价也重新回到了市场领先地位&#xff0c;全年上涨了130%&#xff0c;远远超过了标普500指数24%的涨…

数据库结构、数据对比及同步

目录 一、场景二、操作Navicat Premium 一、场景 部署服务时需要确保开发环境的数据库与生产环境的数据库结构、数据一致 这时可以通过Navicat Premium、SQLyog等工具进行数据库对比 二、操作 Navicat Premium 1、选择同步类型 2、选择对比的数据库 3、选择对比参数 4、查看…

预处理详解(#和##运算符、命名约定、#undef​​、命令行定义​、条件编译、头文件的包含​)

目录 一、#和## 1.1#运算符 1.2## 运算符​ 二、命名约定​ 三、#undef​ 四、命令行定义​ 五、条件编译​ 六、头文件的包含​ 4.1 头文件被包含的方式&#xff1a;​ 4.1.1 本地文件包含​ Linux环境的标准头文件的路径&#xff1a;​ VS环境的标准头文件的路径&…

HelloWorld(java)

1.切换盘符&#xff1a;找到刚刚书写的代码 2.编译&#xff1a;javac是JDK提供的编译工具&#xff0c;通过这个工具&#xff0c;把当前路径下下的HelloWorld.java文件编译成class文件 3.运行&#xff1a;java也是JDK提供的一个工具&#xff0c;作用就是用来运行代码&#xff…

【漏洞复现】银达汇智智慧综合管理平台任意文件读取漏洞

Nx01 产品简介 福建银达汇智信息科技股份有限公司成立于2009年&#xff0c;位于福建省福州市&#xff0c;是一家以从事软件和信息技术服务业为主的企业。 Nx02 漏洞描述 银达汇智智慧综合管理平台 FileDownLoad.aspx 存在任意文件读取漏洞&#xff0c;通过漏洞攻击者可下载服务…

项目管理十大知识领域之成本管理

1. 项目成本管理的意义和重要性 项目成本管理是项目管理中至关重要的一部分&#xff0c;它直接关系到项目最终成本和利润的控制&#xff0c;对于企业的可持续发展具有重要意义。通过合理的成本管理&#xff0c;项目能够更好地控制预算&#xff0c;提高效率&#xff0c;降低成本…