填空题 给定程序中,函数fun的功能是:求出形参ss所指字符串数组中最长字符串的长度,其余字符串左边用字符*补齐,使其与最长的字符串等长。字符串数组中共有M个字符串,且串长小于N。
请在程序的下划线处填入正确的内容,使程序得出正确的结果。
注意:部分源程序给出如下。
不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdio.h>
#include<string.h>
#define M 5
#define N 20
void fun(char(*ss)[N])
{int i,j,k=0,n,m,len;
for(i=0;i<M;i++)
{len=strlen(ss[i]);
if(i=0)n=len;
if(len>n){
/**********found**********/
n=len; 1=i;
}
}
for(i=0;i<M;i++)
if(i!=k)
{m=n;
len=strlen(ss[i]);
/**********found**********/
for(j= 2;j>=0;j--)
ss[i][m--]=ss[i][j];
for(j=0;j<n-len;j++)
/**********found**********/
3="*";
}
}
main()
{char ss[M][N]={"shanghai","guangzhou","beijing","tianjin","chongqing"};
int i;
printf("/nThe original strings are:/n");
for(i=0;i<M;i++)
printf("%s",ss[i]);
printf("/n");
fun(ss);
printf("/nThe result:/n");
for(i=0;i<M;i++)
printf("%s",ss[i]);
}
【正确答案】
【答案解析】(1)k (2)len (3)ss[i][j] [解析] 填空1:使用变量k来保存第几个字符串是最长的字符串,所以应填k。
填空2:利用for循环把原字符串右移至最右边存放,字符串的长为len,所以应填len。
填空3:左边用字符*补齐,所以应填ss[i][j]。