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为文本串的长度。在最坏情况下,朴素算法需要进行大量的不必要比较,效率较低。
在上述代码中,我们使用了两个指针i
和j
分别表示文本串和模式串的索引,通过嵌套循环进行匹配的过程。外层循环控制文本串的起始位置,内层循环用于比较文本串和模式串的字符。如果任何字符不匹配,则内层循环中断,并将文本串的指针向后移动一位,重新开始下一轮匹配。如果内层循环成功执行完毕,即完整匹配了模式串中的所有字符,则说明在文本串中找到了匹配,并打印匹配的位置。外层循环继续,直到遍历完整个文本串。