C语言题目一道……谁来解答????
函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字...
函数ReadDat()实现从文件in.dat中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数writeDat()把结果xx输出到文件out.dat中。
条件:从字符串中间一分为二,右边部分按字符的ASCII值升序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加排序,字符仍放在原位置上。
例如:位置 0 1 2 3 4 5 6 7 8
源字符串 d c b a h g f e
8 7 6 5 9 1 2 3 4
则处理后字符串 e f g h d c b a
1 2 3 4 9 8 7 6 5
部分源程序存在文件prog1.c中。
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
void jsSort()
{
char x[41],y[40];
char zj;
int i,j,k,b,th,max;
for(i=0;i<20;i++)
{
max=strlen(xx[i]);
if(max%2!=0){b=1;zj=xx[i][max/2];}
else b=0;
for(j=max/2+b;j<max;j++)
for(k=j+1;k<max;k++)
if(xx[i][j]>xx[i][k])
{
th=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=th;
}
strncpy(y,xx[i],max/2);
strcpy(x,xx[i]+max/2+b);
if(b==1)
{
x[max/2]=zj;
}
strcpy(xx[i],x);
strcat(xx[i],y);
xx[i][max]='\0';
}
}
我不知道为什么运行出来总有两行错了 展开
条件:从字符串中间一分为二,右边部分按字符的ASCII值升序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加排序,字符仍放在原位置上。
例如:位置 0 1 2 3 4 5 6 7 8
源字符串 d c b a h g f e
8 7 6 5 9 1 2 3 4
则处理后字符串 e f g h d c b a
1 2 3 4 9 8 7 6 5
部分源程序存在文件prog1.c中。
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
void jsSort()
{
char x[41],y[40];
char zj;
int i,j,k,b,th,max;
for(i=0;i<20;i++)
{
max=strlen(xx[i]);
if(max%2!=0){b=1;zj=xx[i][max/2];}
else b=0;
for(j=max/2+b;j<max;j++)
for(k=j+1;k<max;k++)
if(xx[i][j]>xx[i][k])
{
th=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=th;
}
strncpy(y,xx[i],max/2);
strcpy(x,xx[i]+max/2+b);
if(b==1)
{
x[max/2]=zj;
}
strcpy(xx[i],x);
strcat(xx[i],y);
xx[i][max]='\0';
}
}
我不知道为什么运行出来总有两行错了 展开
展开全部
你真厉害,居然能把问题复杂成这样。我粘贴你的运行,可不止两行是错的哦~
标准答案随便找找就可以,现就以你的做法来修改。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char xx[20][80];
void readDat();
void writeDat();
void jsSort()
{
char x[40],y[40];
char temp,zj;
int i,j,k,b,max;
for(i=0;i<20;i++)
{
max=strlen(xx[i]);
if(max%2!=0)
{b=1;
zj=xx[i][max/2];
}
else b=0;
for(j=max/2+b;j<max-1;j++)
for(k=j+1;k<max;k++)
if(xx[i][j]>xx[i][k])
{
temp=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=temp;
}
strncpy(y,xx[i],max/2);
y[max/2]='\0';
strcpy(x,xx[i]+(max+1)/2);
if(b==1) {x[max/2]=zj;x[max/2+1]='\0';}
else x[max/2]='\0';
strcpy(xx[i],x);
strcat(xx[i],y);
}
}
void main()
{
readDat();
jsSort();
writeDat();
}
void readDat()
{
FILE *in;
int i=0;
char *p;
in = fopen("IN.DAT", "r");
while(i<20 && fgets(xx[i], 80, in) != NULL)
{
p = strchr(xx[i],'\n');
if(p)
*p = 0;
i++;
}
fclose(in);
}
void writeDat()
{
FILE *out;
int i;
system("CLS");
out = fopen("OUT.DAT", "w");
for(i=0; i<20; i++)
{
printf("%s\n", xx[i]);
fprintf(out, "%s\n", xx[i]);
}
fclose(out);
}
标准答案随便找找就可以,现就以你的做法来修改。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char xx[20][80];
void readDat();
void writeDat();
void jsSort()
{
char x[40],y[40];
char temp,zj;
int i,j,k,b,max;
for(i=0;i<20;i++)
{
max=strlen(xx[i]);
if(max%2!=0)
{b=1;
zj=xx[i][max/2];
}
else b=0;
for(j=max/2+b;j<max-1;j++)
for(k=j+1;k<max;k++)
if(xx[i][j]>xx[i][k])
{
temp=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=temp;
}
strncpy(y,xx[i],max/2);
y[max/2]='\0';
strcpy(x,xx[i]+(max+1)/2);
if(b==1) {x[max/2]=zj;x[max/2+1]='\0';}
else x[max/2]='\0';
strcpy(xx[i],x);
strcat(xx[i],y);
}
}
void main()
{
readDat();
jsSort();
writeDat();
}
void readDat()
{
FILE *in;
int i=0;
char *p;
in = fopen("IN.DAT", "r");
while(i<20 && fgets(xx[i], 80, in) != NULL)
{
p = strchr(xx[i],'\n');
if(p)
*p = 0;
i++;
}
fclose(in);
}
void writeDat()
{
FILE *out;
int i;
system("CLS");
out = fopen("OUT.DAT", "w");
for(i=0; i<20; i++)
{
printf("%s\n", xx[i]);
fprintf(out, "%s\n", xx[i]);
}
fclose(out);
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
程序的逻辑没错的,if(xx[i][j]>xx[i][k])这段代码有错!因为你用的字符类型,字符类型使不能比较的,如果你是用C语言的话 可以用auoi函数转换成整型在进行比较。
程序我没运行过,不过应该没问题了
程序我没运行过,不过应该没问题了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
努力啊,明天三级考试!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询