C语言朴素算法

c 复制代码
#include <stdio.h>
#include <string.h>

// 朴素算法,用于字符串匹配
void naiveMatch(char* text, char* pattern) {
    int textLength = strlen(text);              // 计算文本串长度
    int patternLength = strlen(pattern);        // 计算模式串长度

    for (int i = 0; i <= textLength - patternLength; i++) {    // 外层循环控制文本串的起始位置
        int j;
        for (j = 0; j < patternLength; j++) {     // 内层循环用于比较文本串和模式串的字符
            if (text[i + j] != pattern[j]) {      // 如果任何字符不匹配,则内层循环中断
                break;
            }
        }
        if (j == patternLength) {                 // 如果内层循环成功执行完毕,则找到匹配
            printf("在位置 %d 处找到匹配\n", i);
        }
    }
}

int main() {
    char text[] = "ABABDABACDABABCABAB";
    char pattern[] = "ABABCABAB";
    naiveMatch(text, pattern);       // 使用朴素算法进行字符串匹配
    return 0;
}

朴素算法是一种最简单直观的字符串匹配算法,其时间复杂度为O(m*n),其中m为模式串的长度,n为文本串的长度。在最坏情况下,朴素算法需要进行大量的不必要比较,效率较低。

在上述代码中,我们使用了两个指针ij分别表示文本串和模式串的索引,通过嵌套循环进行匹配的过程。外层循环控制文本串的起始位置,内层循环用于比较文本串和模式串的字符。如果任何字符不匹配,则内层循环中断,并将文本串的指针向后移动一位,重新开始下一轮匹配。如果内层循环成功执行完毕,即完整匹配了模式串中的所有字符,则说明在文本串中找到了匹配,并打印匹配的位置。外层循环继续,直到遍历完整个文本串。

相关推荐
潇冉沐晴7 分钟前
2026CCCC第三次模拟赛 部分题解
算法
WolfGang00732123 分钟前
代码随想录算法训练营 Day32 | 动态规划 part05
算法·动态规划
碧海银沙音频科技研究院1 小时前
1-1杰理蓝牙SOC的UI配置开发方法
人工智能·深度学习·算法
啊我不会诶1 小时前
2024CCPC长春邀请赛
算法
珂朵莉MM1 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--启发式算法+操作因子设计
人工智能·算法
CS创新实验室3 小时前
CS实验室行业报告:AI算法工程师就业分析报告
人工智能·算法
XiYang-DING3 小时前
【LeetCode】Hash | 136.只出现一次的数字
算法·leetcode·哈希算法
wayz113 小时前
Day 3:逻辑回归与分类预测
算法·分类·逻辑回归
tankeven3 小时前
HJ176 【模板】滑动窗口
c++·算法
网域小星球4 小时前
C 语言从 0 入门(十二)|指针与数组:数组名本质、指针遍历数组
c语言·算法·指针·数组·指针遍历数组