strstr()函数工作原理与自写实现

本文深入探讨了C语言中的strstr()函数的工作原理,并提供了自定义实现该函数的示例,帮助读者理解字符串搜索的核心逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

void putOneByOneP(char *s);
char *strstrM1 (char str[], char mod[]);
char *strstrM2 (char str[], char mod[]);

int main(void)
{
	char s[] = "What's your name?";
	char s2[] = "name";
	putOneByOneP(s);//打印每个字符地址,以便检查strstr()函数是否正确工作 
	char *p = strstrM2(s, s2);//strstr()函数返回索引,以下校验的结果 
	if(p != NULL)
		printf("%s找到了%s!返回地址%p,存储的是 %c\n", s, s2, p, *p);
	else 
		printf("%s未找到%s!\n",s, s2);
	printf("%s", (p != NULL) ? "真的找到了!\n":"真的没找到!\n");//较为简明的检验 
	 
	return 0;
}
void putOneByOneP(char *s)
{
	char *p =s;//最后要用s初始值,所以用p拷贝一份
	while (*s != '\0')
	{
		printf("[%c] %p\n", *s, s);
		++s;
	}
	
} 

char *strstrM1 (char str[], char mod[])
{
	char *s = str, *m = mod;//没必要的城市化,但能明确意图 
	for (;*str != '\0'; ++str)
	{
		for (s = str, m = mod; *m != '\0' && *s == *m; ++s,++m)
			;
		if (*m == '\0')
			return (char *)str;
	}
	return NULL; 
} 

char *strstrM2 (char str[], char mod[])
{
	int i, j, k;
	for (i = 0; str[i]!= '\0'; ++i)
	{
		for (j = 0,k = i; mod[j] != '\0' && str[k] == mod[j]; ++j, ++k)
			;
		if (mod[j] == '\0')
			return &str[i];
	}
	return NULL;
}


 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值