方法1:利用循环求取
int My_Strlen(char arr[])
{
int count = 0;
while (arr[count] != '\0')
{
count++;
}
return count;
}
利用循环,只要字符串中的字符不为‘\0’,循环就会一直进行,查找数组中的下一个值,直到字符为‘\n’。
方法2:利用递归
int my_strlen(char* str)
{
int count = 1;
if (*str != '\0')
return count + my_strlen(str+1);
else
return 0;
}
利用递归,递归结束条件为本函数中的else return 0;每递归成功一次就会使count的值加一,由此来计算出字符串的长度。
方法三:利用指针
int My_Strlen(char arr[])
{
int count = 0;
while (arr[count] != '\0')
{
count++;
}
return count;
}
这个函数我们利用了指针减指针可以得到同一段空间中,这两个指针之间有多少个元素的特点,通过函数返回,从而达到对字符串字符个数计算的要求。
主函数:
int main()
{
char arr[] = "qwertyuiop";
int len = My_Strlen(arr);
printf("%d\n", len);
return 0;
}