C语言模拟实现strstr函数

char * strstr ( const char * str1 , const char * str2 );
该函数是进行字符串截取的,将需截取的字符串中的目标字符串的第一次出现的首地址返回,如果需要得到某个特定的字符串需要多次截取。
模拟实现:
        思路是建立两个循环,外层循环控制指针在源字符串中进行向后移动,内层循环控制与源字符串某个字符的地址相同的目标字符串指针和源字符串该字符指针不断向后移动比较。比如源字符串“123456”和目标字符串“456”,当外层循环指针移动到字符4的地址时,内层循环指针同时开始目标字符串中移动,经过456字符的比较,如果目标字符串指针移动到‘\0’,则说明查找成功。在上述过程中,需要不断保存每次内层循环开始时源字符串指针和目标字符串指针,方便下次内层循环的比较过程。
//模拟实现strstr
const char* my_strstr(const char* target,const char* sub)
{
	assert(target != NULL);
	assert(sub != NULL);
	//->target
	const char* start = target;
	const char* move = NULL;
	//->sub
	const char* sub_start = NULL;
	while (*start) {
		sub_start = sub;
		move = start;
		while (*start&&*move&&*move==*sub_start) {
			move++;
			sub_start++;
		}
		if (*sub_start == '\0') {
			return start;
		}
		start++;
	}
	return NULL;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值