朴素模式匹配算法

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>  
#include <string.h>  

#define MAXSIZE 100  // 定义最大字符串长度  

// 朴素模式匹配算法函数  
// 返回子串在主串中的位置(从0开始计数),如果未找到则返回-1  
int naivePatternMatching(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;
            }
        }
        // 如果内层循环正常结束(即j等于patternLength),则表示匹配成功  
        if (j == patternLength) 
        {
            return i+1;  // 返回匹配开始的位置(从0开始)  
        }
    }
    // 未找到匹配项  
    return -1;
}

int main() 
{
    char text[MAXSIZE];
    char pattern[MAXSIZE];

    // 输入主串  
    printf("请输入主串:\n");
    scanf("%s", text);

    // 输入子串  
    printf("请输入子串:\n");
    scanf("%s", pattern);

    // 调用朴素模式匹配算法函数  
    int position = naivePatternMatching(text, pattern);

    // 输出匹配结果  
    if (position != -1) 
    {
        printf("子串在主串中的位置是:%d\n", position);
    }
    else 
    {
        printf("未找到子串。\n");
    }

    return 0;
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值