求助,南开100题的请教
函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。
条件:从字符串中间一分为二,左边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。
#include <stdio.h>
#include <string.h>
#include <conio.h>
char xx[20][80];
void jsSort()
{ int i,j,k,strl,half;
char temp;
for(i=0;i <20;i++)
{ strl=strlen(xx[i]);
half=strl/2;
for(j=0;j <half-1;j++)
for(k=j+1;k <half;k++)
if(xx[i][j] <xx[i][k])
{ temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;}
for(j=half-1,k=strl-1;j> =0;j--,k--)
{ temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;}以上两行是什么意思,高手解释下,谢谢啊
}
}
[解决办法]
for(j=half-1,k=strl-1;j >=0;j--,k--)
{ temp=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=temp;}
处理第i条字符串,把这个字符串的从最后一个字符起,长度为half的字串和从half个字符起到第一个字符的字串交换位置。