【库函数源码剖析系列】(3) strstr

strstr:

// strstr
#include <stdio.h>

char *Strstr(const char *strLong, const char *strShort)
{
	char *cp = (char *)strLong;	// cp是当前strShort的头在strLong中的位置
	char *pL = NULL;
	char *pS = NULL;
	
	if ('\0' == *strShort)
		return (char *)strLong;
	
	while ('\0' != *cp)
	{
		pL = cp;
		pS = (char *)strShort;
		
		while ( ('\0' != *pL) && ('\0' != *pS) && (*pL == *pS) )
		{
			pL++;
			pS++;
		}
		
		if ('\0' == *pS)	// strShort比完了
			return cp;
		
		cp++;	// 不匹配或strLong比完了而strShort还没比完
	}
	
	return NULL;	
}

int main(int argc, char **argv)
{
	char str[] =    "lazy";
	char string[] = "The quick brown dog jumps over the lazy fox";
	char fmt1[] =   "         1         2         3         4         5";
	char fmt2[] =   "12345678901234567890123456789012345678901234567890";
	
	char *pdest = NULL;
	int result = 0;
	printf( "String to be searched:\n\t%s\n", string );
	printf( "\t%s\n\t%s\n\n", fmt1, fmt2 );
	pdest = Strstr( string, str );
	result = pdest - string + 1;
	
	if( pdest != NULL )
		printf( "%s found at position %d\n\n", str, result );
	else
		printf( "%s not found\n", str );
	
	return 0;
}

用的是暴力的字符串匹配算法。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值