问答题 给定程序中,函数fun的功能是:利用指针数组对形参ss所指字符串数组中的字符串按由长到短的顺序排序,并输出排序结果。ss所指字符串数组中共有N个字符串,且串长小于M。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:部分源程序在文件BLANK1.C中。 不得增行或删行,也不得更改程序的结构! 试题程序: #include<stdio.h> #include<string.h> #define N 5 #define M 8 void fun(char(*ss)[M]) { char*ps[N],*tp;int i,j,k; for(i=0;i<N;i++) ps[i]=ss[i]; for(i=0 ;i<N一1;i++){ /*********found*********/ k= 【1】 ; for(j=i+1;j<N; j++) /*********found*********/ if(strlen(ps[k])<strlen ( 【2】 ))k=j; /*********found*********/ tp=ps[i]; ps[i]=ps[k]; ps[k]= 【3】 ; } printf("\nThe string after sorting by length:\n\n"); for(i=0;i<N;i++)puts(ps[i]); } main() {char ch[N][M]={"red","green","blue","yellow","black"); int i; printf("\nThe original string\n\n"); for(i=0;i<N;i++) puts(ch[i]);printf("\n'); fun(ch); }
【正确答案】正确答案:(1)i (2)ps[j] (3)tp
【答案解析】解析:本题是按字符串的长短进行排序。 填空1:外循环每循环一次,k应保存当前的i值,所以应填i。 填空2:使用内循环对i+1后面的字符串长度进行比较,所以应填ps[j]。 填空3:此处的作用是交换两个变量的值,所以应填tp。