求一个字符串可以用很多种方法,比如:库函数、if循环、while循环、do...while...循环、以及递归等。
循环的核心是当遇到‘\0’为止;
递归的核心看图:
看代码:
#include<stdio.h>
#include<windows.h>
#include<assert.h>
int my_strlen1(const char *str)//while循环
{
assert(str != (NULL));
int i = 0;
while((*str++) != '\0')
{
i++;
}
return i;
}
int my_strlen2(const char *str)//递归
{
assert(str != (NULL));
if (*str == '\0')
return 0;
else
return 1 + my_strlen2(str + 1);
}
int my_strlen3(const char *str)//for循环
{
assert(str != (NULL));
int i = 0;
for (i = 0; *str != '\0'; i++)
{
*str++;
}
return i;
}
int my_strlen4(const char *str)//do...while...循环
{
assert(str != (NULL));
int i = 0;
do
{
*str++;
i++;
} while ((*str) != '\0');
return i;
}
int my_strlen5(const char *str)//递归的一句话表达式,用到逗号表达式。
{
return assert(*str), str == 0 ? 0 : 1 + my_strlen2(str + 1);
}
int main()
{
char arr[] = "abcde";
int ret = strlen(arr);
int ret1 = my_strlen1(arr);
int ret2 = my_strlen2(arr);
int ret3 = my_strlen3(arr);
int ret4 = my_strlen4(arr);
int ret5 = my_strlen5(arr);
printf("%d %d %d %d %d %d\n", ret, ret1, ret2, ret3, ret4, ret5);
system("pause");
return 0;
}
运行结果:
求字符串长度最简单的无非就是库函数,但是到面试的时候,你必须向面试官展现你的知识储备,
多种途径能让你更好的面对面试官。