改错题

给定程序MODI1.C中函数fun的功能是:读入一个字符串(长度小于20),将该字符串中的所有 字符按ASCII码升序排序后输出。

例如,若输入edcba,则应输出abcde。

请改正程序中的错误,使它能输出正确的 结果。

注意:不要改动main函数,不得增行或删行, 也不得更改程序的结构!

给定源程序如下。

【正确答案】

(1) for(i=strlen(t)-1; i; i--)

或 for(i=strlen(t)-1; i>0; i--)

(2)  if(t[j]>t[j+1])

【答案解析】

(1 )本题是利用选择法对数组元素进行比较排 序。所谓选择法,是依次用当前取得的元素和其后面的元素进行比较,在第一个元素和其后面的元素进行比较时,可以借助中间变量来对两个数进行交换,要保证第一个元素始终存放数组中的最大数, 以后依次挑选出次大数,这样最终的数组就是有序 的。strlen函数所求得的字符串长度包括字符串结束符,所以要减1。

(2)这里是一个分析逻辑错误,题中要求按升序排序,所以应改为if(t[j]>t[j+1])。