问题 问答题

下列给定程序中,函数fun的功能是:用冒泡法对6个字符串按由小到大的顺序排列。
请改正程序中的错误,使它能得出正确的结果。
注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include<stdlib.h>
#include<string.h>
#include<conio.h>
#include<stdio.h>
#define MAXLINE 20
fun(char*pstr[6])

lnt i,j;
char *p;
for(i=O;i<5;i++)

/********found********/
for(j=i+l,j<6,j++)

if(strcmp(*(pstr+i)*(pstr+j))>0)

P=*(psfr+i);
/********found********/
*(pstr+i)=pstr+j;
*(pstr+j)=p;




void main()

int i;
char*pstr[6],str[6][MAXLINE];
system("CLS");
for(i=O;i<6;i++)
pstr[i]=str[i];
printf("\nEnter 6 string(1 string at eachline):\n");
for(i=0;i<6;i++)
scanf("%s",pstr[i]);
fun(pstr);
printf("The strings after sorting:\n");
for(i=O;i<6;i++)
printf("%s\n"pstr[i]);

答案

参考答案:for(j=i+1;j<6;j++) (2)*(pstr+i)=*(pstr+j);

解析:
本题关键字有:冒泡排序算法;for循环语句;指针数组。
[微分析]
(1)for语句的各表达式之间应用“;”隔开。
(2)数组元素可以用指针表示,*(pstr+i)表示pstr所指向数组的第i个元素,同理*(pstr+j)表示pstr所指向数组的第j个元素。
冒泡排序法的基本思想是:将待排序元素从前往后扫描,将相邻的两个元素逆行比较,若发现前面的元素大于后面的元素。则将两者进行互换,这样处理一遍之后,最大的元素就排到了最后面,对剩下的元素重复上述过程,不断地将较小的元素往前移动,将较大的元素往后移动,依次类推,完成排序。

解答题
单项选择题