首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
函数ReadDat()实现从文件in.dar中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数Wr
函数ReadDat()实现从文件in.dar中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数Wr
admin
2010-06-27
68
问题
函数ReadDat()实现从文件in.dar中读取20行数据存放到字符串数组xx中(每行字符串长度均小于80)。请编制函数jsSort(),其函数的功能是:以行为单位对字符串按给定的条件进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件out.dat中。
条件:从字符串中间一分为二,左边部分按字符的ASCII值降序排序,排序后左边部分与右边部分进行交换。如果原字符串长度为奇数,则最中间的字符不参加处理,字符仍放在原位置上。
例如:位置 0 1 2 3 4 5 6 7 8
源字符串 a b c d h g f e
1 2 3 4 9 8 7 6 5
则处理后字符串 h g f e d c b a
8 7 6 5 9 4 3 2 1
部分源程序已经给出。
请勿改动主函数main()、读数据函数ReadDat()和输出数据函数WriteDat()的内容。
#include <stdio.h>
#include <string.h>
#include <conio.h>
char xx[20][80];
void jsSort()
{
}
void main()
{
ReadDat();
jsSort();
WriteDat();
}
ReadDat()
{
FILE *in;
int i=0;
char *p;
in=fopen("in.dat","r");
while(i<20&&fgets(xx
,80,in)!=NULL)
{
p=strchr(xx
,’In’);
if(p)*p=0;
i++;
}
fclose(in);
}
WriteDat()
{
FILE *out;
int i;
clrscr();
out=fopen("out.dar","w");
for(i=0;i<20;i++)
{
printf("%s\n",xx
);
fprintf(out,"%s\n",xx
);
}
fclose(out);
}
选项
答案
void jsSort() { int i,j,k,strl,half; char ch; 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]) { ch=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=ch;} for(j=half-1,k=strl-1;j>=0;j--,k--) { ch=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=ch;} } }
解析
该程序属于字符串处理类型的题目。
本题的解题思路是:先确定左边字符串的长度,然后按ASCII值对其进行降序排列,其他的字符不做处理,然后以中间元素为中心左右两边的元素交换位置。左边字符串的长度可以通过整个字符串的长度计算出来,降序排列的算法是每次选定一个位置的元素和它后面的所有元素相比较,如果比后面的元素小则两者交换,完成比较一趟后,此位置的元素大于其后面所有的元素。比较一直进行到所有元素均被访问后结束,一共需要比较half趟,每趟需要比较half-j次。左右元素互换可以通过设定两个标记变量,分别指示要交换的两个位置(左边最后一位与右边最后一位,依此类推),每当左右两个元素交换一次后,两标记变量就分别减1,即分别向左或向右移动一位,两元素交换的时候还需要设定一个临时变量。
程序首先调用ReadDat()函数。读入数据到xx数组中再由jsSort()函数进行处理。最后由WriteDat()函数写回到out.dar文件中。
答案解析如下:
void jsSort()
{
int i,j,k,strl,half; /*定义变量,strl代表字符串的长度,half代表字符串一半的长度*/
char ch; /*定义字符型变量*/
for(i=0;i<20;i++) /*遍历20行数据*/
{
strl=strlen(xx
); /*将第i行字符串个数赋给变量strl*/
half=strl/2; /*将每行一半字符的个数赋给half*/
for(j=0;j<half-1;j++) /*利用二重for循环,对每行左半部分按字符的ASCII值降序排序*/
for(k=j+1;k<half;k++)
if(xx
[j]<xx
[k]) /*判断前一个元素ASCII值是否小于后一个元素*/
{ ch=xx
[j]);
xx
[j]=xx
[k];
xx
[k]=ch;)
/*若小于二者交换位置*/
for(j=half-1,k=strl-1;j>=0;j--,k--) /*交换左右两边元素位置*/
{ch=xx
[j];xx
[j]=MX
[k];
xx
[k]=ch;)
}
}
转载请注明原文地址:https://kaotiyun.com/show/cq5Z777K
本试题收录于:
三级信息管理技术题库NCRE全国计算机三级分类
0
三级信息管理技术
NCRE全国计算机三级
相关试题推荐
关于最早的IM系统的描述中,正确的是()。
关于Telnet中NVT功能的描述中,错误的是()。
设系统中有3种类型的资源(A,B,C)和5个进程(P1,P2,P3,P4,P5),A资源的数量是17,B资源的数量是6,C资源的数量为19。在T0时刻系统的状态如下表:系统采用银行家算法实施死锁避免策略,若当前系统剩余资源(A,B,C)为(2,
在文件系统中,文件的逻辑块与存储介质上物理块存放顺序一致的物理结构是()。
当使用进程撤销原语撤销进程时,正确的过程顺序是()。
在下图所示的UNIX树形文件目录结构中,方框代表目录,椭圆代表文件,根目录root常驻内存,其他文件和目录均在磁盘中存放。其中,用户A和B是同组用户,他们的目录分别为A和B,其目录及其他的子目录和文件的属性如下表所示。下列操作中,哪些是可以正确
系统调用与一般过程调用是不同的,下列对它们的调用程序和被调用程序的描述中,正确的是()。
操作系统作为系统软件,位于软件系统的哪一个层面?()
从简单页式存储管理方案发展到虚拟页式存储管理方案,页表项中通常需要增加的信息是()。
在虚拟页式系统中,当需要进行页面置换时,选择将驻留在内存中时间最长的一页调出的策略是()。
随机试题
你进入新单位后,发现工作很辛苦,工作强度远远超过你的心理预期。你会怎么办?
反应PCl3(g)+Cl2(g)PCl5(g),298K时KΘ=0.767,此温度下平衡时,如p(PCl5)=p(PCI3),则p(C12)=
【背景】某建筑物地下室挖土方工程,内容包括:挖基础土方和基础土方回填,基础土方回填采用打夯机夯实,除基础回填所需土方外,余土全部用自卸汽车外运800m至弃土场。提供的施工场地,已按设计室外地坪—0.20m平整,土质为三类土,采取施工排水措施。
为完成工程项目施工,发生于该工程施工过程中招标人要求计列的费用项目为()。
行政复议期间,有下列情形之一的,行政复议终止()。
外部招聘员工会为企业带来新鲜的血液。但是在筛选时最大的问题是()。
劳动教养适用的对象,是指对有违法行为,而又不追究刑事责任的人。()
A、 B、 C、 D、 B
某单位的员工工资表如下图所示。当员工基本工资小于2000元时,绩效工资=基本工资×9%×业绩点;当员工基本工资大于等于2000元时,绩效工资=基本工资×8%×业绩点。若要计算绩效工资,可先在F3单元格中输入(1)______,并向垂直方向拖动填充柄
Inancienttimesthemostimportantexaminationswerespoken,notwritten.IntheschoolsofancientGreeceandRome,testingus
最新回复
(
0
)