我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C++怎么实现strStr()函数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C++怎么实现strStr()函数

本文小编为大家详细介绍“C++怎么实现strStr()函数”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++怎么实现strStr()函数”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

Implement strStr() 实现strStr()函数

Implement strStr().

Return the index of the first occurrence of needle in haystack, or -1 if needle is not part of haystack.

Example 1:

Input: haystack = "hello", needle = "ll"
Output: 2

Example 2:

Input: haystack = "aaaaa", needle = "bba"
Output: -1

Clarification:

What should we return when needle is an empty string? This is a great question to ask during an interview.

For the purpose of this problem, we will return 0 when needle is an empty string. This is consistent to C"s strstr() and Java"s indexOf().

这道题让我们在一个字符串中找另一个字符串第一次出现的位置,那首先要做一些判断,如果子字符串为空,则返回0,如果子字符串长度大于母字符串长度,则返回 -1。然后开始遍历母字符串,这里并不需要遍历整个母字符串,而是遍历到剩下的长度和子字符串相等的位置即可,这样可以提高运算效率。然后对于每一个字符,都遍历一遍子字符串,一个一个字符的对应比较,如果对应位置有不等的,则跳出循环,如果一直都没有跳出循环,则说明子字符串出现了,则返回起始位置即可,代码如下:

class Solution {public:    int strStr(string haystack, string needle) {        if (needle.empty()) return 0;        int m = haystack.size(), n = needle.size();        if (m < n) return -1;        for (int i = 0; i <= m - n; ++i) {            int j = 0;            for (j = 0; j < n; ++j) {                if (haystack[i + j] != needle[j]) break;            }            if (j == n) return i;        }        return -1;    }};

我们也可以写的更加简洁一些,开头直接套两个 for 循环,不写终止条件,然后判断假如j到达 needle 的末尾了,此时返回i;若此时 i+j 到达 haystack 的长度了,返回 -1;否则若当前对应的字符不匹配,直接跳出当前循环,参见代码如下:

解法二:

class Solution {public:    int strStr(string haystack, string needle) {        for (int i = 0; ; ++i) {            for (int j = 0; ; ++j) {                if (j == needle.size()) return i;                if (i + j == haystack.size()) return -1;                if (needle[j] != haystack[i + j]) break;            }        }        return -1;    }};

读到这里,这篇“C++怎么实现strStr()函数”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C++怎么实现strStr()函数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C++怎么实现strStr()函数

本文小编为大家详细介绍“C++怎么实现strStr()函数”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++怎么实现strStr()函数”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Implement str
2023-06-19

C语言模拟实现strstr函数的代码怎么写

这篇文章主要介绍了C语言模拟实现strstr函数的代码怎么写的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言模拟实现strstr函数的代码怎么写文章都会有所收获,下面我们一起来看看吧。strstr函数介绍C
2023-07-02

c++中strstr函数用法

c++ 中的 strstr() 函数在指定字符串中搜索子字符串,返回子字符串中第一个字符的位置或 null。函数使用 kmp 算法,先对子字符串进行预处理,提高搜索效率。C++ 中 strstr() 函数用法定义和语法strstr()
c++中strstr函数用法
2024-05-09

c语言中strstr函数的用法

strstr() 函数可搜索字符串中的子字符串,返回第一个匹配子字符串的指针或 null(未找到)。用法步骤如下:1. 从字符串开头搜索;2. 逐个字符比较,找到匹配项或到达字符串结尾;3. 找到则返回匹配字符指针,未找到则返回 null。
c语言中strstr函数的用法
2024-04-29

怎么使用PHP中的strstr()函数

这篇文章主要介绍了怎么使用PHP中的strstr()函数,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。php有什么用php是一个嵌套的缩写名称,是英文超级文本预处理语言,它的
2023-06-14

C语言函数strstr如何使用

函数strstr用于在一个字符串中搜索另一个字符串的出现位置。它的声明如下:```cchar *strstr(const char *haystack, const char *needle);```其中,haystack表示要搜索的字符串
2023-09-29

C++怎么实现softmax函数

本篇内容主要讲解“C++怎么实现softmax函数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++怎么实现softmax函数”吧!背景今天面试字节算法岗时被问到的问题,让我用C++实现一个s
2023-06-30

php中strstr函数有什么用

这篇文章主要为大家展示了“php中strstr函数有什么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“php中strstr函数有什么用”这篇文章吧。在PHP中,strstr()函数用于判断字符
2023-06-20

C#构造函数怎么实现

本篇内容介绍了“C#构造函数怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!选择C#构造函数基类对象总是在任何派生类之前构造的。因此基
2023-06-17

PHP strstr()函数的用法是什么

PHP strstr()函数用于在字符串中查找指定的子字符串,并返回从子字符串开始的剩余部分。它的语法如下:strstr(string $haystack, mixed $needle, bool $before_needle = fals
2023-10-10

c++函数的重载怎么实现

这篇文章主要讲解了“c++函数的重载怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“c++函数的重载怎么实现”吧!1.函数重载概述作用:函数可以相同,提高复用性函数重载必须满足的条件:
2023-06-29

C++中怎么实现回调函数

今天就跟大家聊聊有关C++中怎么实现回调函数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C++回调函数代码示例:#include < string> #include < iost
2023-06-17

怎么实现C++虚函数表中的虚函数

这篇文章主要介绍“怎么实现C++虚函数表中的虚函数”,在日常操作中,相信很多人在怎么实现C++虚函数表中的虚函数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么实现C++虚函数表中的虚函数”的疑惑有所帮助!
2023-06-17

c语言怎么实现函数重载

在C语言中,没有直接支持函数重载的特性。函数重载是一个面向对象编程语言(如C++)提供的特性,它允许定义名称相同但参数列表不同的多个函数。在C语言中,可以通过以下方式模拟函数重载:1. 使用不同的函数名:为不同的功能使用不同的函数名,例如`
2023-10-25

C语言怎么实现memcpy与memmove函数

本文小编为大家详细介绍“C语言怎么实现memcpy与memmove函数”,内容详细,步骤清晰,细节处理妥当,希望这篇“C语言怎么实现memcpy与memmove函数”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一
2023-06-29

C#中怎么实现一个取整函数

本篇文章为大家展示了C#中怎么实现一个取整函数,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。C#取整函数使用实例:Math.Round是"就近舍入",当要舍入的是5时与"四舍五入"不同(取偶数),如
2023-06-17

C#中怎么实现一个回调函数

C#中怎么实现一个回调函数,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。什么是C#回调函数?C#回调函数是应用程序提供给Windows系统DLL或其它DLL调用的函数,一般用于
2023-06-18

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录