本题要求实现一个函数,用于计算有n个元素的指针数组s中最长的字符串的长度。
函数接口定义:
int max_len( char *s[], int n );
其中n
个字符串存储在s[]
中,函数max_len
应返回其中最长字符串的长度。
裁判测试程序样例:
#include <stdio.h> #include <string.h> #include <stdlib.h> #define MAXN 10 #define MAXS 20 int max_len( char *s[], int n ); int main() { int i, n; char *string[MAXN] = {NULL}; scanf("%d", &n); for(i = 0; i < n; i++) { string[i] = (char *)malloc(sizeof(char)*MAXS); scanf("%s", string[i]); } printf("%d\n", max_len(string, n)); return 0; } /* 你的代码将被嵌在这里 */
输入样例:
4
blue
yellow
red
green
输出样例:
6
int max_len( char *s[], int n )
{
int len,i,max=0;
for(i=0;i<n;i++)
{
len=strlen(*(s+i));
if(len>max)
{
max=len;
}
}
return max;
}
用函数算长度即可,注意函数中的格式,这里是指针数组,所以用*(s+i)让循环跑起来,比较基础。