实现strstr

本文介绍了一个字符串查找函数的实现方法,该方法用于在一个源字符串中查找目标子字符串的位置。如果找到子字符串,则返回其在源字符串中的起始位置;如果没有找到,则返回null。文章通过具体的代码示例展示了这一过程。

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

 

从字符串str1中查找是否有字符串str2,如果有,从str1中的str2位置起,返回str1的指针,如果没有,返回null。

 

 

     图解思路

判断s1,s2是否相等,若相等,则s1,s2同时向后移一位;若不相等,cur后移一位,s1=cur。循环判断。

 

代码实现

#include<stdio.h>
#include<assert.h>

char* my_strstr(const char*str, const char*substr)
{
	assert(str != NULL);
	assert(substr != NULL);
	const char *s1;
	const char *s2;
	const char *cur = str;
	if (*substr == '\0')      
	{
		return (char *)str;
	}
	while (*cur)
	{
		s1 = cur;
		s2 = substr;
		while (*s1 && *s2 && *s1 == *s2)
		{
			s1++;
			s2++;
		}
		if (*s2 == '\0')
		{
			return (char *)cur;
		}
		cur++;
	}
	return NULL;
}

int main()
{
	const char *p = "abcdefghij";
	const char *q = "cdef";
	char *ret = my_strstr(p, q);
	if (ret == NULL)
	{
		printf("不存在\n");
	}
	else
	{
		printf("%s\n", ret);
	}
	return 0;
}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值