使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,函数fun的功能是:利用指针数组对形参ss所指字符串数组中的字符串按由长到短的顺序排序,并输出排序结果。ss所指字符串数组中共有

admin2020-06-02  35

问题 使用VC++2010打开考生文件夹下blank1中的解决方案。此解决方案的项目中包含一个源程序文件blank1.c。在此程序中,函数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=ss
  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;ps=ps[k];
  ps[k]=【3】
  }
  printf("\nThe string after sorting by length:\n\n");
  for(i=0;i<N;i++)puts(ps);
}
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);printf("\n");
  fun(ch);
}

选项

答案(1)i (2)ps[j] (3)tp

解析 本题是按字符串的长短进行排序。
  填空1:外循环每循环一次,k应保存当前的i值,所以应填i。
    填空2:使用内循环对i+1后面的字符串长度进行比较,所以应填ps[j]。
    填空3:此处的作用是交换两个变量的值,所以应填tp。
转载请注明原文地址:https://kaotiyun.com/show/LeCp777K
0

最新回复(0)