字符串函数的模拟

目录

strlen函数的模拟

strlen函数展示

strlen函数模拟

strcpy函数的模拟

strcpy函数展示

strcpy函数模拟

strcat函数的模拟

strcpy函数展示

strcpy函数模拟

strcmp函数的模拟

strcmp函数展示

strcmp函数模拟

strstr函数的模拟

strstr函数展示

strstr函数模拟


strlen函数的模拟

strlen函数展示

#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[] = {"abcdef"};
	int len = strlen(arr1);
	printf("%d", len);
	return 0;
}

strlen函数模拟

strlen函数计算\0以前的字符有几个

#include <stdio.h>
#include <assert.h>
size_t my_strlen(const char* str)//这是为了增加鲁棒性,使原来传过来的不能改
{
    assert(str);//防止str的是空的
    const char* start = str;
    const char* end = str;
    while (*end != '\0')
    {
        end++;
    }
    return end - start;//start是原来的初始地址
}
int main()
{
    char arr[] = {"abcdef"};
    int len = my_strlen(arr);
    printf("%d", len);
    return 0;
}

strcpy函数的模拟

strcpy函数展示

#include <stdio.h>
#include <string.h>
int main()
{
    char arr1[20] = {"abcd"};
    char arr2[] = {"ccccccc"};
    strcpy(arr1, arr2);
    printf("%s\n", arr1);
    return 0;
}

strcpy函数模拟

strcpy又叫复制函数,将arr2的字符复制到arr1里面

#include <stdio.h>
#include <assert.h>
char* my_strcpy(char* dest, const char* scr)//那个char*是原来strcpy规定的
{
    assert(dest);
    assert(scr);
    char* ret = dest;//把初始地址先存下来,不然直接得到后面的dest早就不是初地址
    while (*dest++ = *scr++)
    {
        ;
    }
    return ret;
}
int main()
{
    char arr[20] = { "abc" };
    char arr1[] = { "abcdef" };
    my_strcpy(arr, arr1);
 //printf("%s\n", my_strcpy(arr, arr1));这样也行
    printf("%s\n", arr);
    return 0;
}

strcat函数的模拟

strcat函数展示

#include <stdio.h>
#include <string.h>
int main()
{
	char arr2[] = { "world" };
	char arr1[20] = {"hello "};//注意要在目标的里面加入大小[20]
	strcat(arr1, arr2);//追加字符
	printf("%s\n", arr1);
	return 0;
}

strcat函数模拟

strcat函数又叫追加函数,将后面的字符串加到目标字符串后面

#include <stdio.h>
#include <string.h>
char* my_strcat(char* dest, const char* scr)
{
    //先找目标空间的‘\0’
    char* cur = dest;
    while (*cur != '\0')
    {
        cur++;
    }
    //拷贝源头数据到'\0'之后的空间
    while (*cur++ = *scr++)
    {
        ;
    }
    return dest;//因为原来的dest没有变,还是初始位置
}
int main()
{
    char arr1[20] = {"hello "};
    char arr2[] = { "world" };
    printf("%s\n", my_strcat(arr1, arr2));
    return 0;
}

strcmp函数的模拟

strcmp函数展示

#include <stdio.h>
#include <string.h>
int main()
{
	char arr1[] = {"abcd"};
	char arr2[] = { "abcdef" };
	int ret = strcmp(arr1, arr2);
	if (ret > 0)
		printf("arr1 > arr2\n");
	else if (ret < 0)
		printf("arr1 < arr2\n");
	else
		printf("arr1 = arr2\n");
	return 0;
}

strcmp函数模拟

比较函数

第一个比第二个大的返回一个正数
第一个比第二个小返回一个负数
第一个跟第二个一样返回0

#include <assert.h>
int my_strcmp(const char* s1, const char* s2)
{
    assert(s1 && s2);//保证s1和s2不为0
    while (*s1 == *s2)
    {
        if (*s1 =='\0')//等于0的时候
        {
            return 0;
        }
        s1++;
        s2++;
    }
    return *s1 - *s2;//大于和小于的时候
}
int main()
{
    //char arr1[] = { "abc" };
    //char arr2[] = { "abcd" };

    //char arr1[] = { "abcd" };
    //char arr2[] = { "abc" };

    char arr1[] = { "abc" };
    char arr2[] = { "abc" };
    int ret = my_strcmp(arr1, arr2);
        if (ret > 0)
        printf("arr1 > arr2\n");
    else if (ret < 0)
        printf("arr1 < arr2\n");
    else
        printf("arr1 = arr2\n");
    return 0;
}
 

strstr函数的模拟

strstr函数展示

#include <stdio.h>
int main()
{
	char arr1[] = { "abcdef" };
	char arr2[] = { "bcd" };
	char *p = strstr(arr1, arr2);
	if(p == NULL)
	{
		printf("不存在\n");
	}
	else
		printf("%s\n", p);

	return 0;
}

strstr函数模拟

在一个字符串中找另一个字符串是否存在

存在:返回子串第一次所在的位置

不存在:返回NULL

#include <stdio.h>
char* my_strstr(const char* str1, const char* str2)
{
    const char* s1 = str1;
    const char* s2 = str2;

    const char* p = str1;
    while (*p)//str1不等于\0就可以循环
    {
        s1 = p;//每次比对完又回来
        s2 = str2;//每次比对完又回来
        while (*s1 != '\0' && *s2 != '\0' && (*s1 == *s2))
        {
            s1++;
            s2++;
        }
        if (*s2 == '\0')
        {
            return (char*)p;//找到了
        }
        p++;
    }
    return NULL;//找不到子串;

}
int main()
{
    char arr1[] = { "abcdef" };
    char arr2[] = { "bcd" };
    char *p = my_strstr(arr1, arr2);
    if(p == NULL)
    {
        printf("不存在\n");
    }
    else
        printf("%s\n", p);

    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值