strlen、strcpy、strcmp、strcat、strstr函数的模拟实现
2023-12-28 11:02:53
strlen、strcpy、strcmp、strcat、strstr函数均为字符串处理函数,使用时需要包含头文件string.h
strlen函数
strlen函数主要用于求字符串的长度。
#include <stdio.h>
int my_strlen(const char* str)
{
int count = 0;
while (*str++) //\0的ASCII码是0
{
count++;
}
return count;
}
int main()
{
char ch[] = "student";
printf("%d", my_strlen(ch));
return 0;
}
strlen模拟的其他两种方法
1、用指针相减方法
2、用递归的方法
strcpy函数
原型: ? char* strcpy(char *dest,char *src) ? ?功能:将源字符串复制到目的字符串(包括源字符串最后的\0),函数返回值为目的字符串首地址
?注意事项:1、要保证目的字符数组足够大 ?2、主函数中的目的字符串不能用char*来定义(char*默认定义为常量字符串,内容不可修改)
//1.简单易懂版
#include <stdio.h>
char* my_strcpy(char* dest,char* src)
{
char* ret = dest; //提前保存目的字符串首地址
while (*src != '\0') //*src
{
*dest = *src;
src++;
dest++;
}
*dest = *src; //复制最后的\0
return ret;
}
int main()
{
char ch1[20] = { 0 };
char ch2[] = "student";
printf("%s", my_strcpy(ch1,ch2));
return 0;
}
//2.优化版本
#include <stdio.h>
char* my_strcpy(char* dest, char* src)
{
char* ret = dest; //提前保存目的字符串首地址
while (*dest++ = *src++) //src最后的\0也会复制给dest,且*dest最后的结果是\0(ASCII码为0),退出循环。
{
;
}
return ret;
}
int main()
{
char ch1[20] = { 0 };
char ch2[] = "student";
printf("%s", my_strcpy(ch1, ch2));
return 0;
}
strcmp函数? ??
原型: ?int strcmp(const char* s1,const char* s2) ? ? 功能:逐个比较两个字符串每个字符的大小,返回值>0、=0、<0分别表示第一个字符串大于、等于、小于第二个字符串
#include <stdio.h>
int my_strcpy(const char* s1, const char* s2)
{
while (*s1 == *s2)
{
if (*s1 == '\0')
{
return 0; //两个字符串相等,直接返回,不需要下面的指针++
}
s1++;
s2++;
}
if (*s1 > *s2) //return *s1-*s2;
{
return 1;
}
else
{
return -1;
}
}
int main()
{
int temp = my_strcpy("strlena", "strlena");
if (temp > 0)
{
printf("第一个字符串大");
}
else if (temp < 0)
{
printf("第二个字符串大");
}
else
printf("两个字符串一样大");
return 0;
}
strcat函数
函数原型: ?char* strcat(char* dest,const char* src) ? ?函数功能:将src字符串从dest的\0位置开始复制,一直复制到src的最后
#include <stdio.h>
char* my_strcat(char* dest, char* src)
{
char* ret = dest; //提前保存目的字符串首地址
while (*dest) //找到dest字符串\0的位置
{
dest++;
}
while (*dest++ = *src++) //src最后的\0也会复制给dest,且*dest最后的结果是\0(ASCII码为0),退出循环。
{
;
}
return ret;
}
int main()
{
char ch1[20] ="good ";
char ch2[] = "student";
printf("%s", my_strcat(ch1, ch2));
return 0;
}
strstr函数
函数原型:char* strstr(const char* str1,const char* str2) ?功能:在str1字符串中寻找str2字符串,如果找到,返回str1中指向str2首元素的指针,没有找到返回NULL
思路:分别从str1的第n个元素与str2进行匹配(建立两个指针s1与s2操作),不满足则后移str1的指针(建立第一个指针cur操作)。
退出比较的3个条件:1.s1 != \0,s2 == \0 找到了 2.s2找到了\0 找到了 3.*s1 != *s2
#include <stdio.h>
char* my_strstr(const char* str1, const char* str2)
{
char* cur = (char*)str1;
char* s1 = NULL;
char* s2 = NULL;
if (*str2 == '\0') //特殊情况,str2为'\0'的情况
{
return cur;
}
while (*cur)
{
s1 = cur;
s2 = str2;
while (*s1 && *s2 && *s1 == *s2) //避免str1与str2相等,指针向后移越界访问的情况
{
s1++;
s2++;
}
if (*s2 == '\0')
{
return cur;
}
cur++;
}
return NULL;
}
int main()
{
char ch1[] ="goodsstudents";
char ch2[] ="student";
if (my_strstr(ch1, ch2) == NULL)
{
printf("没找到");
}
else
{
printf("找到了");
printf("%s", my_strstr(ch1, ch2));
}
return 0;
}
文章来源:https://blog.csdn.net/qq_52907930/article/details/135254517
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!