C练习——计算字符串长度,实现strlen功能

发布时间 2023-12-23 13:00:07作者: 王小龙s

strlen是一个库函数,是专门求字符串长度的,只能针对字符串,从参数给定地址向后一直找“\0”,

统计“\0”之前出现的字符的个数。

现给字符串“abcd”,要求写一个计算此字符串长度的函数

 

#include <stdio.h>
int my_strlen(char arr[]); // 函数声明
int main()
{
    char arr[] = "abcd";
    int len = my_strlen(arr);
    printf("%d\n", len);
    return 0;
}
// first: 遍历数组,count计数,if判停止
int my_strlen(char arr[])
{
    int i = 0;
    int count = 0;
    while (1)
    {
        if (arr[i] != '\0')
        {
            count++;
            i++;
        }
        else
            break;

    }
    return count;
}

如果你对数组名和指针有足够理解,那么此代码还可优化

#include <stdio.h>
int my_strlen(char arr[]); // 函数声明
int main()
{
    char arr[] = "abcd";
    int len = my_strlen(arr);
    printf("%d\n", len);
    return 0;
}
// second: 遍历数组,count计数,if判停止
int my_strlen(char arr[]) //数组名就是数组首元素地址
{
    int count = 0;
    while (*arr != '\0')
    {
        count++;
        arr++;
    }
    return count;
}

 

 

 如果你对递归算法有一定理解,那么事情就更简单了

#include <stdio.h>
int my_strlen(char arr[]); // 函数声明
int main()
{
    char arr[] = "abcd";
    int len = my_strlen(arr);
    printf("%d\n", len);
    return 0;
}
// third: 递归
int my_strlen(char arr[]) //数组名就是数组首元素地址相当于 char*str
{
    if (*arr != '\0')
        return 1 + my_strlen(arr + 1);
    else
        return 0;
}

 

 递归过程大致如下: