现场编写类似strstr/strcpy函数

标签(空格分隔): 数据结构与算法 C\C++


一、字符串查找strstr()

题目描述
给定一个字符串A,要求在A中查找一个子串B。
如A="ABCDF",要你在A中查找子串B=“CD”。
在字符串中查找指定字符串的第一次出现的位置,不能找到则返回-1

int Strstr( const char *s,  const char *sub)
{
	if (s == NULL || sub == NULL)
		return -1;
	
	size_t lenstr = strlen(s);
	size_t lensub = strlen(sub);

	if (lenstr < lensub)
		return -1;
	int len = lenstr - lensub;
	int i, j;
	for (i = 0; i <= len; i++)
	{
		for (j = 0; j < lensub; j++)
		{
			if (s[i + j] != sub[j])
				break;
		}
		if (j == lensub)
			return i + 1;
	}
	return -1;
}

二、字符串拷贝strcpy()

满分函数如下:

char* Strcpy(char* strDest, const char *str)
{
	if (strDest == str) { return strDest; }//考虑到源目所指区域有重叠的情况
	assert((strDest != NULL) && (str != NULL));//对源地址和目的地址加非0断言
	char *address = strDest;//为了实现链式操作,将目的地址返回
	while ((*strDest++ = *str++) != '\0');
	return address;
}
posted @ 2016-04-20 19:42  Blackmanba_xzl  阅读(195)  评论(0编辑  收藏  举报