个人专栏:
《零基础学C语言》
strlen函数(Get string length)的功能是求字符串长度
使用注意事项:
在这里主要讲解三种方法模拟实现
size_t my_strlen1(const char* str)
{
assert(str);
int count = 0;
while (*str++)
{
count++;
}
return count;
}
这里我们要记录下字符串的初始位置,等str移动到 ‘\0’ 后,相减得结果
size_t my_strlen2(const char* str)
{
assert(str);
char* start = str;
while (*str)
{
str++;
}
return str - start;
}
递归主要考虑返回条件和子问题
size_t my_strlen3(const char* str)
{
assert(str);
if (*str == '\0')
{
return 0;
}
return my_strlen3(str + 1) + 1;
}
运行结果:
void TestMyStrlen()
{
char arr[] = "abcdef";
size_t len = my_strlen3(arr);
printf("%zd\n", len);
}
strcpy函数(Copy string)的功能是字符串拷贝
使用注意事项:
下面代码最巧妙的地方,在于把字符串的拷贝和 ‘\0’ 的拷贝融合在一起。循环中,先赋值,再判断,最后++。这样就算遇到 ‘\0’ ,也会先拷贝,再判断停止。
char* my_strcpy(char* dst, const char* src)
{
assert(dst && src);
char* ret = dst;
while (*dst++ = *src++)
{
;
}
return ret;
}
运行结果:
strcat函数(Concatenate strings)的功能是字符串追加
使用注意事项:
字符串追加可以理解为两个过程:
char* my_strcat(char* dst, const char* src)
{
assert(dst && src);
char* ret = dst;
while (*dst)
{
dst++;
}
while (*dst++ = *src++)
{
;
}
return ret;
}
运行结果:
strcmp函数(Compare two strings)的功能是字符串比较
使用注意事项:
int my_strcmp(const char* str1, const char* str2)
{
assert(str1 && str2);
while (*str1 == *str2)
{
if (*str1 == '\0')
{
return 0;
}
str1++;
str2++;
}
return *str1 - *str2;
}
运行结果:
strstr函数(Locate substring)的功能是查找子串
使用注意事项:
我们这里采用最直观,容易理解的暴力求解法
是不是光看文字还不理解,我们来看图分析:
首先,(假设dst是s1,src是s2),cur从a开始,s1和s2比较,不相等,再判断s2是否为’\0’,不为0,则cur++
cur再从b开始比较,s1和s2相等,则继续比较
直到s1和s2不相等,再判断s2是否为’\0’,不为0,则cur++
cur再从下一个b开始,同样重复以上步骤……
s2还是不为0,cur++
cur从第三个b开始,s1和s2比较。
这次,直到s1和s2不相等时,s2终于为’\0’,则代表匹配成功,返回地址cur!!!
//暴力求解
char* my_strstr(const char* str1, const char* str2)
{
assert(str1 && str2);
const char* cur = str1;
const char* dst = NULL;
const char* src = NULL;
if (*str2 == '\0')
{
return (char*)str1;
}
while (*cur)
{
dst = cur;
src = str2;
while (*dst == *src)
{
dst++;
src++;
}
if (*src == '\0')
{
return (char*)cur;
}
cur++;
}
return NULL;
}
运行结果:
这种暴力求解的方法比较好理解,但效率却不是很高。其实还有一种高效求子串的方法——KMP算法,在后期会跟大家进行详细讲解。
看到这里了还不给博主扣个:
⛳️ 点赞☀️收藏 ⭐️ 关注!
❤️
拜托拜托这个真的很重要!
你们的点赞就是博主更新最大的动力!
有问题可以评论或者私信呢秒回哦。