C程序的朴素模式搜索算法

c程序的朴素模式搜索算法

C 中的模式匹配– 我们必须查找一个字符串是否存在于另一个字符串中,例如,字符串“algorithm”存在于字符串“naive algorithm”中。如果是找到,然后显示它的位置(即它所在的位置)。我们倾向于创建一个函数,它接收 2 个字符数组,如果匹配则返回位置,否则返回 -1。

Input: txt = "HERE IS A NICE CAP"   pattern = "NICE"Output: Pattern found at index 10Input: txt = "XYZXACAADXYZXYZX"   pattern = "XYZX"Output: Pattern found at index 0   Pattern found at index 9   Pattern found at index 12

我们正在通过朴素模式搜索来解决这个问题。该算法对于较小的文本很有用。 Naive 是一种简单而低效的方法,要查看一个字符串在另一个字符串中出现的位置,就要逐一检查它可能出现的每个位置,以检查它是否存在。

Naive 算法的时间复杂度为O(mn),其中m是要搜索的模式的大小,n是容器字符串的大小。

模式搜索是计算机科学中非常关键的问题。每当我们在记事本/word文件或浏览器或数据库或某些信息中寻找字符串时,模式搜索算法用于显示搜索结果。

算法

naive_algorithm(pattern, text)

输入− 文本和模式

输出− 模式在文本中出现的位置

Start   pat_len := pattern Size   str_len := string size   for i := 0 to (str_len - pat_len), do      for j := 0 to pat_len, do         if text[i+j] ≠ pattern[j], then         break   if j == patLen, then   display the position i, as there pattern foundEnd

示例

 实时演示

#include #include int main (){   char txt[] = "tutorialsPointisthebestplatformforprogrammers";   char pat[] = "a";   int M = strlen (pat);   int N = strlen (txt);   for (int i = 0; i <= N - M; i++){      int j;      for (j = 0; j < M; j++)         if (txt[i + j] != pat[j])      break;      if (j == M)         printf ("Pattern matches at index %d 

", i); } return 0;}

输出

Pattern matches at 6Pattern matches at 25Pattern matches at 39

以上就是C程序的朴素模式搜索算法的详细内容,更多请关注创想鸟其它相关文章!

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

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

相关推荐

  • 检查给定字符串是否是关键字的C程序?

    关键字是在C++库中预定义或保留的单词,具有固定的含义,并用于执行内部操作。C++语言支持超过64个关键字。 每个关键字都以小写字母形式存在,如auto、break、case、const、continue、int等。 C++语言中的32个关键字也可在C语言中使用。 autodoubleintstru…

    2025年12月17日
    000
  • C++程序以给定值找到反正弦

    在三角学中,我们最常使用几个比率:正弦、余弦、正切和其他一些比率。从给定的角度,可以计算这些比率。但是,如果我们有比率值,我们还可以使用反三角函数计算角度。 在本文中,我们将讨论如何通过 C++ 中的反正弦(反正弦)方法从正弦值获取弧度角。 asin() 函数 asin() 方法用于使用反三角正弦函…

    2025年12月17日
    000
  • C程序求第n个偶数

    给定一个数字N,我们需要找到第N个偶数。 偶数是能够被2整除且余数为零的数字。例如2、4、6、8、10等。 如果我们仔细观察偶数列表,我们也可以表示它们为 2*1=2, 2*2=4, 2*3=6, 2*4=8,…2*N。 因此,为了解决这个问题,我们可以简单地将数字N乘以2,这样结果就是…

    2025年12月17日
    000
  • C程序以找到链表的长度

    链接列表使用动态内存分配,即它们相应地增长和收缩。它们被定义为节点的集合。这里,节点有两部分,即数据和链路。数据、链接和链表的表示如下 – 链表的类型 链表有四种类型,如下: – 单链表/ 单链表双/双向链表循环单链表循环双链表 我们使用递归方法求链表长度的逻辑是 &#821…

    2025年12月17日
    000
  • 二分查找的C程序(递归和迭代)

    二分查找算法是一种基于比较和分割机制的算法。二分搜索算法也称为半间隔搜索、对数搜索或二分查找。二分查找算法,在已排序数组中查找目标值的位置。它将目标值与数组的中间元素进行比较。如果该元素等于目标元素,则算法返回找到的元素的索引。如果它们不相等,则搜索算法使用该数组的一半部分,根据值的比较,算法使用前…

    2025年12月17日
    000
  • C++程序来找出至少需要获得多少分才能达到G分的分数

    假设我们有两个数组p和c,每个数组都有D个元素,并且还有另一个数字G。考虑在编程竞赛中,每个问题的分数都基于其难度。问题p[i]的分数为100i。这些p[1] + … + p[D]问题是竞赛中的所有问题。编程网站上的用户有一个数字total_score。用户的total_score是以下…

    2025年12月17日
    000
  • C++程序按值对字典进行排序

    有一些被称为字典的数据结构在各种计算机语言中可用。一种特殊形式的更快的数据结构,它根据键和值存储数据,就是字典。它将键值对保留在那里,以便可以通过键快速搜索某些组件,几乎实时。类似字典的数据结构包含在C++ STL语言标准中。这个数据结构被称为”map“。map生成任何类型的…

    2025年12月17日
    000
  • 十进制转二进制的C语言程序实现

    问题 如何使用C语言中的函数将十进制数转换为二进制数? 解决办法 在在这个程序中,我们在 main() 中调用一个二进制函数。被调用的二进制数转换函数将执行实际的转换。 我们使用的将十进制数转换为二进制数的调用函数的逻辑如下 – while(dno != 0){ rem = dno % …

    2025年12月17日 好文分享
    000
  • C程序检查强数

    给定一个数字’n’,我们需要检查给定的数字是否是强数。 强数是指其所有数字的阶乘之和等于数字’n’。阶乘是指将小于该数字的所有数字(包括该数字)相乘的结果,用!(感叹号)表示。例如:4!= 4x3x2x1 = 24。 因此,要确定一个数字是否是强数,我…

    2025年12月17日
    000
  • C++程序打印8个星星图案

    以金字塔、正方形和菱形等不同格式显示星形图案非常有用常见于基础编程和逻辑构建。我们见过几颗星星学习编程中的循环语句时的数字模式问题。在本文中,我们将在 C++ 中显示由星星组成的数字八 (8)。 在这个程序中,我们取行号 n,它是 8 的上半部分的大小。下半部分将是相同的。八个图案如下所示 带星星的…

    2025年12月17日
    000
  • 获取给定复数的虚部的C++程序

    现代科学在很大程度上依赖于复数的概念,这一概念最初是通过Girolamo Cardano在16世纪引入的在17世纪初建立。复数的公式是 a + ib,其中 a 保留html代码并且b是实数。一个复数被认为有两个部分:实部和虚部()。i或iota的值为√-1。C++中的复数类是一个用于表示复数的类。C…

    2025年12月17日
    000
  • C程序实现校验和

    什么是校验和? 在计算中,校验和是使用算法从较大数据集创建的小尺寸数据,其目的是对较大数据集所做的任何更改都会导致不同的校验和。校验和通常用于验证已传输或存储的数据的完整性,因为数据中的错误或修改可能会导致校验和更改。它们还可以用于验证数据的真实性,因为校验和通常是使用只有发送者和接收者知道的密钥生…

    2025年12月17日
    000
  • 在C程序中,编写自己的幂运算函数,但不能使用乘法(*)和除法(/)操作符

    幂函数是使用乘法运算符进行计算的,即5n等于5*5*5… n次。为了使该函数在不使用乘法(*)和除法(/)运算符的情况下正常工作,我们将使用嵌套循环来重复添加数字n次。 示例 #include using namespace std;int main() { int a= 4 , b = 2; if…

    2025年12月17日
    000
  • 将以下内容翻译为中文:C程序将罗马数字转换为十进制数字

    给出以下是一个将罗马数字转换为十进制数字的C语言算法: 算法 步骤1 – 开始 步骤2 – 在运行时读取罗马数字 步骤3 – 长度: = strlen(roman) 步骤4 – 对于i = 0到长度-1       步骤4.1 – swit…

    2025年12月17日
    000
  • C程序查找形成回文的最小插入次数

    回文是一个与其反转相等的字符串。给定一个字符串,我们需要找到使该字符串成为回文所需的最小插入任意字符的数量。我们将看到三种方法:首先是递归方法,然后我们将记忆化这个解决方案,最后,我们将实现动态规划方法。 递归方法 示例 #include // library for input and outpu…

    2025年12月17日
    000
  • 在C程序中的Windows线程API

    线程是在 Windows API 中使用 CreateThread() 函数创建的,并且就像在 Pthreads 中一样,安全信息、堆栈大小和线程标志等一组属性将传递给该函数。在下面的程序中,我们使用这些属性的默认值。 (默认值最初不会将线程设置为挂起状态,而是使其有资格由 CPU 调度程序运行。)…

    2025年12月17日
    000
  • C程序在数组中找到最小和最大的质数

    问题陈述 给定一个包含 n 个正整数的数组。我们必须找到素数具有最小值和最大值的数字。 如果给定的数组是 – arr [] = {10, 4, 1, 12, 13, 7, 6, 2, 27, 33}then minimum prime number is 2 and maximum pr…

    2025年12月17日
    000
  • 在C程序中使用递归函数的辅助空间?

    这里我们将看到递归函数调用如何需要辅助空间。它与普通函数调用有何不同? 假设我们有一个如下所示的函数 – long fact(int n){ if(n == 0 || n == 1) return 1; return n * fact(n-1);} 该函数是递归函数。当我们像fact(5…

    2025年12月17日
    000
  • C++程序将一个数组推入另一个数组中

    A linear sequential data structure called an array is used to store homogeneous data in a series of memory regions. An array needs to have certain fea…

    2025年12月17日
    000
  • 编写一个C程序,使用elseif语句将数字打印为单词

    问题 在不使用 switch case 的情况下,如何使用 C 编程语言以文字形式打印给定的数字? 解决方案 在此程序中,我们检查三个条件以用单词打印两位数 – if(no99) if(no99) p> 输入的数字不是两位数 else if(no==0) 将第一个数字打印为零 el…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信