递归函数在C++中进行子串搜索

递归函数在c++中进行子串搜索

给定两个字符串 Str 和 subStr 作为输入。目标是确定 subStr 中存在的文本是否作为子字符串存在于 Str 中。如果整个 X 在 Y 中至少出现一次,则字符串 X 称为 Y 的子串。我们将使用递归方法来执行此操作。

例如

输入− Str = “tutorialspoint” subStr=”Point”

输出− 给定字符串不包含子字符串!

解释− 字符串 Point 不是教程点的子字符串

输入− Str = “globalization” subStr=”global”

输出− 给定字符串包含子字符串!

立即学习“C++免费学习笔记(深入)”;

解释 – 字符串global是全球化的子字符串

下面的程序中使用的方法如下

在这种方法中,我们以递归方式检查subStr是否是Str的子字符串。递归的步骤为:-

1.将两个字符串传递给递归函数,其中指针将指向两个字符串的当前字符位置

如果字符串结束但模式还剩下更多字符,则返回 0,因为未找到模式我们到达了字符串的末尾。

如果当前字符是模式中的最后一个字符,则在字符串中找到它,返回 1。

li>

如果两个当前字符相同,则将两个指针移动到下一个位置。

如果两个当前字符不匹配,则将指针移动到下一个位置。将字符串移动到下一个位置。

将输入字符串作为字符数组 Str 和 subStr。

函数 match(char *str1, char *substr1) 接受两个子字符串,如果 substr1 和 str1 相同,则返回 1。

两个指针都指向字符串中存在的字符,最初位于起始位置。

如果 substr 为空,则返回 0。

如果两个字符串都为空,则也返回 0。

如果两个字符串都为空,则也返回 0。 >

如果两个当前字符相等,则使用 match(str1 + 1, substr1 + 1) 递归检查下一个字符

函数 checksubString (char *str2, char *substr2) 接受两个字符串,如果 str2 中存在 substr2,则返回 1。

如果 str2 和 substr2 指向的当前字符相同,则检查是否连续的字符也可以使用 match() 函数进行匹配。如果返回 1,则返回 1。

如果到达 str2 的末尾,则返回 0。

否则递归检查str2 的下一个字符使用 checksubString(str2 + 1, substr2);

如果所有条件都失败,则还使用递归检查checksubString(str2 + 1, substr2);

根据返回值打印结果。

示例

#includeusing namespace std;int match(char *str1, char *substr1){   if (*substr1 == ''){      return 1;   }   if (*str1 == ''){      if(*substr1 != ''){         return 0;      }   }   if (*str1 == *substr1){      return match(str1 + 1, substr1 + 1);   }   return 0;}int checksubString(char *str2, char *substr2){   if (*str2 == *substr2){      if(match(str2, substr2)){         return 1;      }   }   if (*str2 == ''){      return 0;   }   else{      return checksubString(str2 + 1, substr2);   }   return checksubString(str2 + 1, substr2);}int main(){   char Str[]="tutorialspoint";   char subStr[]="point";   if(checksubString(Str,subStr)==1){      cout << "Given string contains substring!";   }   else{      cout << "Given string does not contain substring!"; }   return 0;}

输出

如果我们运行上面的代码,它将生成以下输出

Given string contains substring!

以上就是递归函数在C++中进行子串搜索的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1444146.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 21:05:05
下一篇 2025年12月17日 21:05:19

相关推荐

  • 深入理解Ajax函数及其参数用法

    掌握常用的Ajax函数及其参数详解 Ajax(Asynchronous JavaScript and XML)是一种用于在客户端和服务器之间异步传输数据的技术。它能够实现无需刷新整个页面而更新部分内容,提升了用户体验和性能。本文将详细介绍常用的Ajax函数及其参数,并附带具体的代码示例。 一、XML…

    2025年12月24日
    300
  • 看看CSS中的那些背景图片函数!

    本篇文章带大家了解一下css中的背景图片函数:url()、image()、image-set()、cross-fade()、element()。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 【推荐教程:CSS视频教程 】 url() url函数表示对某个资源的引用,可传入链接以及…

    2025年12月24日 好文分享
    000
  • 聊聊你可能不了解的CSS属性函数 attr()

    本篇文章带大家了解一下css属性函数 attr()。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 属性函数 attr() 用于获取HTML元素里面的属性值,并用于样式中,但目前暂时只能应用于CSS元素中的伪元素。 例子 实现一个Tooltip 立即学习“前端免费学习笔记(深入)”…

    2025年12月24日 好文分享
    000
  • css3中的calc函数浅析_css3

    calc()对大家来说,或许很陌生,不太会相信calc()是css中的部分。但它却是就是css3的一部分,下面这篇文章主要给大家介绍了关于css3中calc函数的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下 前言 其实在之前学习CSS3的时候,我并没有注意到有calc()这个属性,…

    2025年12月24日
    000
  • html怎么设置函数一直运行_html设函数持续运行方法【设置】

    使用JavaScript实现函数持续执行有四种方法:1. 用setInterval按固定间隔重复调用函数;2. 用requestAnimationFrame实现与屏幕刷新同步的高效循环;3. 在async函数中结合while循环和定时延迟避免阻塞主线程;4. 通过事件监听控制标志位,条件性启动或终止…

    2025年12月23日
    000
  • 深入了解numpy转置函数的常见用法和案例分析

    numpy转置函数的常用用法与案例分析 在数据处理、科学计算和机器学习领域中,经常需要对数组或矩阵进行转置操作。转置操作是将一个数组的行与列进行对换的操作,可以通过numpy库的转置函数来实现。本文将介绍numpy转置函数的常用用法,并通过案例分析来进一步了解其应用。 一、numpy转置函数的常用用…

    2025年12月21日
    000
  • 每个前端开发者都应该了解的10个CSS函数

    CSS(层叠样式表)是一种样式表语言,用于描述以 HTML 编写的文档的外观和格式。它是 Web 开发的重要组成部分,因为它允许开发人员控制其网站和应用程序的外观。 在本文中,我们将讨论一些最有用的CSS函数,每个前端开发人员都应该熟悉。这些函数可以用于为您的网站或应用程序添加样式和格式,并可以极大…

    2025年12月21日
    000
  • 深入分析JS函数

    这次给大家带来深入分析js函数,函数声明和函数表达式有什么区别?使用js函数的注意事项有哪些,下面就是实战案例,一起来看一下。 函数声明和函数表达式有什么区别 (*) 函数声明:function bar() {}函数表达式:var fuc = foo(){}1.函数bar将会在整个程序执行前被 ho…

    好文分享 2025年12月21日
    000
  • JavaScript中的尾调用优化与递归_javascript性能

    尾调用优化通过重用栈帧避免递归时的栈溢出。当函数最后一步调用自身且返回其结果时,如阶乘函数factorial(n, acc)在n≤1时返回acc,否则递归调用factorial(n-1, n*acc),此时可进行优化,但JavaScript中仅部分引擎支持。 尾调用优化(Tail Call Opti…

    2025年12月21日
    100
  • 如何实现JavaScript中的递归函数优化?

    优化JavaScript递归函数需通过记忆化避免重复计算,并将递归转换为迭代以防止栈溢出,从而提升性能与健壮性。 优化JavaScript中的递归函数,核心在于两点:避免重复计算(通过缓存)和防止栈溢出(通过迭代化或尾调用优化)。这不仅仅是提升性能,更是在面对复杂算法时确保代码健壮性的关键。 解决方…

    2025年12月20日
    000
  • 如何理解递归?递归在数据结构中的应用

    递归通过函数调用自身将问题分解为更小的子问题,直至达到可直接求解的基本情况。核心包含两部分:基本情况(Base Case)确保递归终止,防止无限循环;递归步骤(Recursive Step)将原问题拆解为更小的同类子问题。以阶乘为例,n == 0 为基本情况,n * factorial(n-1) 为…

    2025年12月20日
    000
  • js怎么判断函数是否存在

    判断javascript函数是否存在的最稳妥方法是使用typeof操作符;2. 若函数存在且为函数类型,typeof返回’function’,可安全调用,否则需提示不存在或类型错误;3. 检查对象方法时应先确认对象存在,再用typeof判断方法是否为函数,避免typeerro…

    2025年12月20日
    000
  • c++中如何使用递归遍历数组_c++递归遍历数组技巧

    递归遍历数组通过分解问题实现,先处理当前元素再递归下一个;2. 反向遍历则利用回溯,在递归调用后处理当前元素,实现从末尾开始输出。 在C++中,递归遍历数组是一种常见的编程技巧,尤其适合理解递归思想和处理分治类问题。虽然循环更直观,但递归能帮助我们以更简洁、函数式的方式处理数据结构。 1. 递归遍历…

    2025年12月19日
    000
  • c++如何通过函数返回一个数组或vector _c++函数返回数组与vector方法

    C++中函数不能直接返回原始数组,但可返回std::vector或std::array。推荐使用std::vector实现动态数组返回,具备自动内存管理与高效优化;固定大小数组宜用std::array,避免裸指针和C风格数组以提升安全性。 在C++中,函数不能直接返回一个原始数组(如 int[]),…

    2025年12月19日
    000
  • c++中如何使用递归实现阶乘_c++递归阶乘实现方法

    递归实现阶乘需定义终止条件和递归调用,C++中factorial(n)函数通过n==0或1时返回1、否则返回n*factorial(n-1)计算阶乘,代码简洁但受限于整型范围与栈深度。 在C++中,递归是一种函数调用自身的方法。实现阶乘时,递归非常直观:n的阶乘等于n乘以(n-1)的阶乘,直到n为0…

    2025年12月19日
    000
  • C语言算法问答集:深入了解递归和回溯

    递归:一种函数自我调用的技术,针对较小的问题不断调用自身,直到满足终止条件为止。回溯:一种试错技术,从一个解或状态开始,逐步探索各种可能结果,直到找到或耗尽所有可能性。 C语言算法问答集:深入了解递归和回溯 递归 什么是递归? 立即学习“C语言免费学习笔记(深入)”; 递归是一种函数自我调用的技术。…

    2025年12月18日
    000
  • C++ 函数的类方法是如何声明和实现的?

    c++++中类方法声明是在类定义中使用访问控制修饰符声明的,实现则在类定义之外,使用类名作为作用域解析运算符。例如,public类方法可在对象上调用,protected和private方法受保护或私有访问限制。 C++ 函数的类方法 声明 类方法是类的一部分,可以在对象上调用。它们在类定义中使用 p…

    2025年12月18日
    000
  • C++ 函数类的方法有哪些访问权限修饰符?

    访问权限修饰符控制对类成员函数的访问级别,包括:public:所有实体可见。protected:同一类和派生类可见。private:仅对同一类可见。 C++ 函数类的方法访问权限修饰符 简介 访问权限修饰符控制对类成员函数的访问级别。C++ 中,有三种访问权限修饰符: public:成员函数对所有实…

    2025年12月18日
    000
  • C++ 函数的类方法可以有哪些类型的访问权限?

    c++++ 类方法的访问权限包括:公有(类内外访问)、保护(类内或派生类访问)和私有(仅类内访问)。公有方法用于 api 和功能,保护方法用于实现内部逻辑,私有方法用于隐藏实现细节。 C++ 函数的类方法访问权限 在 C++ 中,类方法可以具有以下访问权限: 公有 (public):可以在任何地方访…

    2025年12月18日
    000
  • C++ 函数的类方法在实际项目中的应用场景

    在 c++++ 中,类方法与具体对象无关,用于执行与类本身相关的操作。它们可用于:1. 工厂模式:创建对象,无需指定子类类型;2. 实用程序函数:提供与类相关的一般性功能;3. 单例模式:确保只有一个类实例;4. 数据访问层:与数据库等数据源交互。 C++ 函数的类方法在实际项目中的应用场景 在 C…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信