模拟实现strstr 找到母串中是否有与子串相同的部分(代码)

cs 复制代码
//#模拟实现strstr
//char *strstr(const char *str1, const char *str2)
#include <stdio.h>
char* my_s(const char* str1, const char* str2)
{
	//用指针记录两个字符串的起始位置
	const char* s1 = str1;
	const char* s2 = str2;
	//指针记录字符串查找初次相等的位置
	const char* cur = str1;
	while (cur)
	{
		s1 = cur;
		s2 = str2;
		while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2)//循环比较两个字符串
		{
			s1++;
			s2++;
		}
		//cur++;//s1 s2不相等时cur++, 相等时cur指向初次相等的位置不变
		if (*s2 == '\0')//找全相等的字符串  子串s2已经结束
		{
			return cur;
		}
		cur++;//s1 s2不相等时cur++, 相等时cur指向初次相等的位置不变
	}return NULL;//遍历完没有找到相同的字符串
}


int main()
{
	const char* str1 = "adbbbcef";
	const char* str2 = "bbc";
	char* ret;
	ret = my_s(str1, str2);
	printf("%s", ret);
	return 0;
}
相关推荐
杰杰批15 分钟前
第十四届蓝桥杯大赛软件赛国赛C/C++研究生组
c语言·c++·蓝桥杯
花之亡灵23 分钟前
.net6 中实现邮件发送
笔记·c#·.net·代码规范
LuoYaFu33 分钟前
文件上传做题记录
笔记
吴梓穆1 小时前
UE5学习笔记 FPS游戏制作43 UI材质
笔记·学习·ue5
aaaweiaaaaaa1 小时前
蓝桥杯c ++笔记(含算法 贪心+动态规划+dp+进制转化+便利等)
c语言·数据结构·c++·算法·贪心算法·蓝桥杯·动态规划
rrtt_23231 小时前
UE5 尝试接入 C# 脚本方案
ue5·c#·csharp·unrealcsharp
学会870上岸华师1 小时前
c语言学习16——内存函数
c语言·开发语言·学习
密码小丑2 小时前
玄机-apache日志分析
网络·笔记·apache
XYN612 小时前
【嵌入式面试】
笔记·python·单片机·嵌入式硬件·学习
s_yellowfish4 小时前
Maven笔记
java·笔记·maven