字符串函数的实现

1.strcpy函数的实现
原型声明:char *strcpy(char *dest, const char *src);
头文件:#include < string.h>
功能:把从src地址开始且含有‘\0’结束符的字符串复制到以dest开始的地址空间
说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
返回指向dest的指针。

#include<stdlib.h>
#include<assert.h>
#include<stdio.h>
char *my_strcpy(char *dest, const char *src)
{
    char *ret = dest;
    assert(dest);
    assert(src);
    while (*dest++ = *src++)
    {
        NULL;
    }
    return dest;
}
int main()
{
    char arr1[40];
    char *arr2 = "hello,world";
    my_strcpy(arr1, arr2);
    printf("%s\n", arr1);
    system("pause");
    return 0;
}

2.strcat函数的实现

原型: char *strcat(char *dest,char *src);

功能:把src所指字符串添加到dest结尾处(覆盖dest结尾处的’\0’)并添加’\0’。

说明:src和dest所指内存区域不可以重叠且dest必须有足够的空间来容纳src的字符串。
返回指向dest的指针。


#include<stdlib.h>
#include<assert.h>
#include<stdio.h>
#define MAX 20
char *my_strcat(char *dest, const char *src)
{
    char * ret = dest;
    assert(dest);
    assert(src);
    while (*dest)
    {
        dest++;
    }

    while (*dest = *src)
    {
        dest++;
        src++;
    }
    return dest;
}
int main()
{
    char arr1[MAX] = "abcd";
    char *arr2 = "bcde";
    my_strcat(arr1, arr2);
    printf("%s\n", arr1);
    system("pause");
    return 0;
}

3.strlen函数的实现
unsigned int strlen(char *s);
头文件:string.h
格式:strlen (字符数组名)
功能:计算给定字符串的(unsigned int型)长度,不包括’\0’在内
说明:返回s的长度,不包括结束符NULL。

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
int my_strlen(const char*dest)
{
    assert(dest);
    int len=0;
    while ((*dest++) !='\0')
    {
        len++;

    }
    return len;
}
int main()
{
    int ret = 0;
    char arr[] = "456789";
    ret=my_strlen(arr);
    printf("%d", ret);
    system("pause");
    return 0;
}

利用指针实现:

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
int my_strlen(const char*dest)
{
    assert(dest);
    const char *p = dest;
    while ((*p++) != '\0')
    {
        NULL;
    }
        return p - dest - 1;
}
int main()
{
    int ret = 0;
    char arr[] = "456789";
    ret=my_strlen(arr);
    printf("%d", ret);
    system("pause");
    return;
}

另外,我们可以使用递归调用实现。

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
size_t my_strlen(char * dest)
{
    assert(dest);
    if (*dest == '\0')
        return 0;
    else
        return (1 + my_strlen(++dest));
}
int main()
{
    char *str = "abcdef";
    unsigned int  ret = my_strlen(str);
    printf("%lu", ret);
    system("pause");
    return 0;
}

上面的代码也可以写的更加简洁:

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
size_t my_strlen(char * dest)
{
    assert(dest);
    return ('\0'!=*dest) ? 1 + my_strlen(++dest): 0;
}
int main()
{
    char *str = "abcdef";
    unsigned int  ret = my_strlen(str);
    printf("%lu", ret);
    system("pause");
    return 0;
}

上述代码巧妙地利用了条件语句,
4.strcmp函数
字符串比较函数,
原型为:int strcmp(const char *s1, const char *s2);
说明:字符串大小的比较是以ASCII 码表上的顺序来决定,此顺序亦为字符的值。strcmp()首先将s1 第一个字符值减去s2 第一个字符值,若差值为0 则再继续比较下个字符,若差值不为0 则将差值返回。例如字符串”Ac”和”ba”比较则会返回字符”A”(65)和’b’(98)的差值(-33)。
规则:当s1 < s2时,返回为负数;当s1=s2时,返回值= 0;当s1>s2时,返回正数。

#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
int my_strcmp(const char *str1, const char * str2)
{
    assert(str1);
    assert(str2);
    while (*str1&&*str2&&*str1 == *str2)
    {
        str1++;
        str2++;
    }
    return *str1-*str2;

}
int main()
{
    int ret;
    char *arr1 = "abcdef";
    char *arr2 = "abcdel";
    ret=my_strcmp(arr1, arr2);

    printf("%d", ret);
    system("pause");
    return 0;
}

strstr()函数

包含文件:string.h
函数名: strstr
函数原型:
char *strstr(char *str1, const char *str2);
语法:
* strstr(str1,str2)
str1: 被查找目标 string expression to search.
str2: 要查找对象 The string expression to find.
返回值:若str2是str1的子串,则返回str2在str1的首次出现的地址;如果str2不是str1的子串,则返回NULL。

//实现strstr()函数
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
char *my_strstr(const char *dest,const char *src)
{
    assert(dest);
    assert(src);
    const char *p = dest;
    const char *q = src;
    const char * start = NULL;
    while (*p)
    {
        start = p;
        while (*p&&*q&&*p==*q)
        {
            p++;
            q++;
        }
        if (*q == '\0')
        {
            return (char *)start;
        }
        p = start + 1;
        q = src;
    }
    return NULL;
}
int main()
{

    char dest[] = "abcdef";
    char *src1 = "bcd";
    char *ret = my_strstr(dest, src1);

    printf("%s\n", ret);
    system("pause");
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值