第六十三练 字符串匹配 - KMP算法

简介: 第六十三练 字符串匹配 - KMP算法

第六十三练 字符串匹配 - KMP算法

要求:1、输入两个字符串 2、实现KMP算法,判断第一个字符串是否包含第二个字符串 3、输出匹配结果

第六十二练答案

以下是一个简单的C语言实现,用于模糊匹配两个字符串,支持通配符'*':

#include <stdio.h>
#include <stdbool.h>

bool fuzzyMatch(const char *target, const char *pattern) {
    while (*target != '\0' && *pattern != '\0') {
        if (*pattern == '*') {
            // Handle '*' wildcard
            while (*(pattern + 1) == '*') {
                pattern++;
            }

            while (*target != '\0' && *pattern != '\0' && *target != *pattern) {
                target++;
            }
        } else if (*pattern != *target) {
            return false; // Mismatch
        }

        target++;
        pattern++;
    }

    // Check for remaining characters in pattern
    while (*pattern == '*') {
        pattern++;
    }

    return *pattern == '\0'; // If pattern is fully processed, it's a match
}

int main() {
    char target[100], pattern[100];

    printf("Enter the target string: ");
    scanf("%s", target);

    printf("Enter the pattern string: ");
    scanf("%s", pattern);

    if (fuzzyMatch(target, pattern)) {
        printf("Match found\n");
    } else {
        printf("No match found\n");
    }

    return 0;
}

此程序通过循环遍历目标字符串和模式字符串,处理通配符'*',并判断是否匹配。如果匹配成功,输出"Match found";否则,输出"No match found"。

答案和解析会在次日公布

注意事项

编写代码的时候,需要注意以下几点问题:

  • 头文件的引用需要放在代码的最顶部
  • 每个C语言程序中必须包含一个 main函数
  • void main(){}
  • int main(){return 0;}
  • C语言中每一行的结尾处必须要使用分号结尾
  • C语言中的引号需要使用双引号,双引号都是以一对一对的情况出现的
  • 在scanf键盘输入代码中,要使用 & 加变量名来读取一个键盘输入
  • 赋值语句是将右边的值赋给左边的变量,顺序不能反了
  • 需要注意代码的缩进格式,缩进为4个空格或者一个tab键为一组,但是要保证整篇代码里面风格一致,要么都是4个空格缩进,要么都是使用一个tab进行缩进
  • 需要养成随手保存的习惯,保存的快捷键一般是 ctrl + s
  • 注意大括号的使用,大括号是代码块,代表了一个块的代码是放在一起的
  • 注意整数型和实数型的转换,如果将实数赋值给一个整形变量,那么实数的小数部分将会被舍去;
  • 注意除法中,如果除数和被除数都是整数,那么结果也会是一个整数,小数部分会自动舍弃
  • 成对出现的标点符号
  • 单引号,双引号,小括号,中括号,大括号等,一般不单独出现
  • 如果代码有问题,然后附近又刚好有这些成对符号,请着重关注
  • 定义变量时,该打的逗号应该打上,不能写掉了
  • 编写++符号时,不要误写成了ff
  • 一个程序里面只能有一个main函数,除了main函数的其他函数都不能叫这个名字
  • 在调用函数时,入参都是使用的逗号隔开,一定不要使用分号隔开
  • 换行符是\n,不能错误写成/n
  • 输入输出格式化
  • %.2f是保留两位小数
  • %d对应整数
  • %c对应字符
  • %f对应实数
  • 不要写错或者写漏了
  • if条件语句当前行不能加分号,不然这个语句就没有意义了
  • while语句和if语句一样,当行不能加分号
  • 不建议使用goto语句,因为那样会造成程序结构的混乱,导致不可读

更多

「欢迎来到C语言每日一练服务!」

在现代技术的飞速发展中,编程已经成为一项不可或缺的技能。C语言作为一门经典的编程语言,奠定了计算机科学的基石,为学习其他编程语言打下了坚实的基础。为了帮助大家更好地掌握C语言,我们特别推出了每日一练服务,旨在提供系统性、全面性的学习支持。

「我们的服务特点包括:」

  1. 「日常练习题目:」 每天我们会提供一道C语言练习题目,涵盖基础知识、算法、数据结构等多个领域。这些题目既有难度,又具有实际应用价值,帮助你锻炼编程技能。
  2. 「详细解析:」 我们不仅提供每道题的标准答案,还会提供详细的解析和优秀代码示例。通过对解题思路的深入剖析,你能够更好地理解和掌握各种编程技巧。
  3. 「互动学习社区:」 通过微信文章评论区建立了一个互动学习社区,供学员们交流讨论。你可以在这里提问问题、分享经验,与其他学员一起成长。
  4. 「个性化学习建议:」 根据你的学习表现,我们会为你推荐相应难度的练习题,确保你的学习过程既具挑战性,又不至于过于困难,保持学习的动力和兴趣。

「参与每日一练的好处:」

  • 「持续学习提升技能:」 每日坚持练习,你的编程技能将会得到持续提升,不断进步。
  • 「增强自信心:」 通过解决各种类型的问题,你将建立起对自己技能的信心,更加轻松应对编程挑战。
  • 「拓宽思路:」 每道题都是一个小挑战,通过解决这些问题,你将培养出灵活的思维,更好地应对实际编程工作中的挑战。
  • 「为未来发展奠定基础:」 无论你是初学者还是有一定经验的程序员,C语言每日一练都将为你未来的编程发展奠定坚实的基础。

加入我们的C语言每日一练服务,一起挑战编程难题,不断提升自己,走向编程高手的道路!


目录
相关文章
|
2月前
|
算法
【算法】滑动窗口——找到字符串中所有字母异位词
【算法】滑动窗口——找到字符串中所有字母异位词
|
1天前
|
算法
KMP算法
KMP算法
5 0
|
2月前
|
算法 C++
A : DS串应用–KMP算法
这篇文章提供了KMP算法的C++实现,包括计算模式串的next数组和在主串中查找模式串位置的函数,用于演示KMP算法的基本应用。
|
2月前
|
算法 Java
掌握算法学习之字符串经典用法
文章总结了字符串在算法领域的经典用法,特别是通过双指针法来实现字符串的反转操作,并提供了LeetCode上相关题目的Java代码实现,强调了掌握这些技巧对于提升算法思维的重要性。
|
3月前
|
自然语言处理 算法 搜索推荐
字符串相似度算法完全指南:编辑、令牌与序列三类算法的全面解析与深入分析
在自然语言处理领域,人们经常需要比较字符串,这些字符串可能是单词、句子、段落甚至是整个文档。如何快速判断两个单词或句子是否相似,或者相似度是好还是差。这类似于我们使用手机打错一个词,但手机会建议正确的词来修正它,那么这种如何判断字符串相似度呢?本文将详细介绍这个问题。
243 1
|
2月前
|
算法
KMP算法
KMP算法
18 0
|
2月前
|
算法 C++
惊爆!KPM算法背后的秘密武器:一行代码揭秘字符串最小周期的终极奥义,让你秒变编程界周期大师!
【8月更文挑战第4天】字符串最小周期问题旨在找出字符串中最短重复子串的长度。KPM(实为KMP,Knuth-Morris-Pratt)算法,虽主要用于字符串匹配,但其生成的前缀函数(next数组)也可用于求解最小周期。核心思想是构建LPS数组,记录模式串中每个位置的最长相等前后缀长度。对于长度为n的字符串S,其最小周期T可通过公式ans = n - LPS[n-1]求得。通过分析周期字符串的特性,可证明该方法的有效性。提供的C++示例代码展示了如何计算给定字符串的最小周期,体现了KPM算法在解决此类问题上的高效性。
53 0
|
3月前
|
算法 Java
KMP算法详解及其在字符串匹配中的应用
KMP算法详解及其在字符串匹配中的应用
|
3天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于GA遗传优化的GroupCNN分组卷积网络时间序列预测算法matlab仿真
该算法结合了遗传算法(GA)与分组卷积神经网络(GroupCNN),利用GA优化GroupCNN的网络结构和超参数,提升时间序列预测精度与效率。遗传算法通过模拟自然选择过程中的选择、交叉和变异操作寻找最优解;分组卷积则有效减少了计算成本和参数数量。本项目使用MATLAB2022A实现,并提供完整代码及视频教程。注意:展示图含水印,完整程序运行无水印。
|
1天前
|
机器学习/深度学习 算法 数据安全/隐私保护
基于MSER和HOG特征提取的SVM交通标志检测和识别算法matlab仿真
### 算法简介 1. **算法运行效果图预览**:展示算法效果,完整程序运行后无水印。 2. **算法运行软件版本**:Matlab 2017b。 3. **部分核心程序**:完整版代码包含中文注释及操作步骤视频。 4. **算法理论概述**: - **MSER**:用于检测显著区域,提取图像中稳定区域,适用于光照变化下的交通标志检测。 - **HOG特征提取**:通过计算图像小区域的梯度直方图捕捉局部纹理信息,用于物体检测。 - **SVM**:寻找最大化间隔的超平面以分类样本。 整个算法流程图见下图。