strstr函数——一个字符串是否是另一个字符串的子串

头文件:

string.h 

函数的声明:

char *strstr( const char *str1, const char *str2 )

                                       字符串               可能的子串

返回值:

如果str2在str1中出现,返回str2第一次出现在str1的位置的地址

如果str2没有在str1中出现,返回NULL空指针

用法:

给两个字符串,第一个为字符串,第二个为要判断的子串

实例:

#include<stdio.h>
#include<string.h>
int main() {
	char str1[] = "abcijkghijk";//仅返回第一次出现子串的地址
	char str2[] = "ijk";
	strstr(str1, str2);
	char* ret = strstr(str1, str2);
	if (NULL == ret) {
		printf("找不到字符串\n");
	}
	else {
		printf("找到了\n");
		printf("%s\n", ret);//并把之后的字符打印
	}
	return 0;
}

函数的实现:

#include<stdio.h>
#include<string.h>
char* my_strstr(char* str1, char* str2) {
	char* s1 = 0;
	char* s2 = 0;
	char* p = str1;
	while (*p != '\0') {//跳出此循环则证明以查找完原字符串,无子串
		s1 = p;
		s2 = str2;
		while (*s1 && *s2 && *s1 == *s2) {//保证*s1!='\0',   *s2!='\0',   *s1==*s2才可以运行
			s1++;                       // s1未到字符串末   s2未到字符串末    *s1与*s2相同时
			s2++;

		}
		if (*s2 == '\0') {//找到子串
			return p;
		}
		p++;

	}
	return NULL;

}
int main() {
	char str1[] = "abbbcbdef";
	char str2[] = "bbc";
	my_strstr(str1, str2);
	char* ret = strstr(str1, str2);
	if (NULL == ret) {
		printf("找不到字符串\n");
	}
	else {
		printf("找到了\n");
		printf("%s\n", ret);//并把之后的字符打印
	}
	return 0;
}

 

 

直到*s2=‘\0’时结束循环,通过判断if (*s2 == '\0')返回子串首地址

若整个过程没有轮到*s2=‘\0’,则证明没有子串,同时也应有*p='\0',原字符串查找完,没有子串,返回空指针NULL

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

橘子13

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值