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; }
递归过程大致如下:
标签:count,arr,int,my,练习,char,字符串,strlen From: https://www.cnblogs.com/xiaowanglong/p/17922987.html