首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
在文件in33.dat中有200个正整数,且每个正整数均在1000至9999之间。函数readDat()的功能是读取这200个数并存放到数组aa中。请编制函数jsSort(),该函数的功能是:要求按照每个数的后3位的大小进行升序排列,将排序后的前10个数存
在文件in33.dat中有200个正整数,且每个正整数均在1000至9999之间。函数readDat()的功能是读取这200个数并存放到数组aa中。请编制函数jsSort(),该函数的功能是:要求按照每个数的后3位的大小进行升序排列,将排序后的前10个数存
admin
2009-02-15
143
问题
在文件in33.dat中有200个正整数,且每个正整数均在1000至9999之间。函数readDat()的功能是读取这200个数并存放到数组aa中。请编制函数jsSort(),该函数的功能是:要求按照每个数的后3位的大小进行升序排列,将排序后的前10个数存入数组
bb中,如果数组bb中出现后3位相等的数,则对这些数按原始4位数据进行降序排列。最后调用函数writeDat()把结果bb输出到文件out33.dat中。
例如:处理前 6012 5099 9012 7025 8088
处理后 9012 6012 7025 8088 5099
注意:部分源程序已给出。
请勿改动主函main()、读函数readDat()和写函数writeDat()的内容。
试题程序:
#include<stdio.h>
#include<string.h>
#include<conio.h>
int aa[200],bb[10];
void readDat();
void writeDat();
void jsSort()
{
}
Void main()
{
readDat ();
jsSort();
writeDat();
}
void readDat()
{
FILE *in;
int i;
in=fopen("in33.dat","r");
for(i=0;i<200;i++) fscanf(in,"%d ",&aa
);
fclose(in);
}
void writeDat()
{
FILE *out;
int i;
clrscr();
out=fopen("out33.dat","w");
for(i=0;i<10;i++)
{
printf("i=%d, %d\n", i+1, bb
);
fprintf(out, "%d\n",bb
);
}
fclose(out);
}
选项
答案
void jsSort() { int i, j,data; for(i=0;i<199;i++) for(j=i+1;j<200;j++) { if(aa[i]%1000>aa[j]%1000) /*按照每个数的后3位的大小进行升序排列*/ { data=aa[i]; aa[i]=aa[j]; aa[j]=data; } else if(aa[i]%1000==aa[j]%1000 /*如果后3位数值相等,则对这些数值按原始4位数据 进行降序排列* / if(aa[i]<aa[j]) { data=aa[i]; aa[i]=aa[j]; aa[j]=data; } } for(i=0;i<10;i++) /*将排好序的前十个数存入数组bb中*/ bb[i]=aa[i]; }
解析
本题考查的知识点如下:
(1) 循环结构的嵌套。
(2) 选择结构的嵌套。
(3) 特殊运算符“%”的使用。
(4)数据的升降序排列。
在该题中,首先要解决的问题是如何把题中4位数转换成符合要求的3位数。这里要用到一个比较特殊的运算符%,它的功能是取余。将4位数除以1000取余则得到要求的3位数。根据题意,若后3位相等,则按照原数据进行降序排序,所以在这里要加一个选择结构进行判断。对数据进行排序,可以使用最简单的“选择排序法”。即第一次从第一个数据开始和所有后面的数据进行比较,与比它大(小)的数据交换位置,将数据中最大(小)的数交换到最前面。第二次从第二个数据开始与后面的数据进行比较,将此次比较中最(小)的数据交换至第二个位置,直至最后一个数据。
转载请注明原文地址:https://www.kaotiyun.com/show/RUfZ777K
本试题收录于:
三级信息管理技术题库NCRE全国计算机三级分类
0
三级信息管理技术
NCRE全国计算机三级
相关试题推荐
()由通信控制处理机、通信线路与其他通信设备组成。
路由器的吞吐量涉及()吞吐量和()吞吐量两个方面的内容。
层次之间的上联带宽与下一级带宽之比一般控制在()。
()模式是指无线网络规模扩充或无线和有线网络并存时的通信方式。
VTP有三种工作模式:()、()和VTPTransparent。
局域网交换机的基本功能之一是建立和维护一个表示MAC地址与交换机端口对应关系的()。
标准访问控制列表只能检查数据包的()。
路由表中“[110/112]”含义是该条路由信息源的()为110,()是112。
在实现文件系统时,可采用“目录项分解法”加快文件目录检索速度。假设目录文件存放在磁盘上,每个盘块512字节。文件控制块有64字节,其中文件名占8字节,文件控制块分解后,第一部分占有10字节(包括文件名和文件内部号),第二部分占56字节(包括文件内部号和文件
控制器从CPU完全接管对总线的控制,数据交换不经过CPU,而直接在内存和硬盘之间进行。该I/O设备控制方式称为()。
随机试题
标志着教育学科成为独立学科的著作是夸美纽斯的()
当时谏臣陈子昂建议诛之而旌其闾。(《驳复仇议》)旌:闾:
Whenhewentout,hewouldwearsunglasses______nobodywouldrecognizehim.
某画家2010年9月将其精选的书画作品交由某出版社出版,从出版社取得报酬80000元。该笔报酬在缴纳个人所得税时适用的税目是()。
()是基金产品的募集者和管理者。
有这样一则长诗:“祖国,您在哪里?……在西藏和平解放的签字笔里,在雄赳赳气昂昂跨过鸭绿江的雄壮歌声里,在新宪法散发出的真真书香里……”诗中“新宪法”指的是()。
改革开放以来,我国经济在总体上迅速发展,取得举世瞩目成就的同时,发展不平衡问题也逐渐突出。城乡发展差距较大,区域发展差距明显,社会事业等发展相对滞后。对此,我们的正确认识是()。①经济社会发展是一个螺旋式前进的过程,平衡是相对的.而不平衡是绝对的②
波表(wave table)就是波形表,下列有关它的叙述正确的是( )
Youwillhearanotherfiverecordings.Eachspeakeristalkingonthephone.Foreachrecording,decidethemainreasonforthe
Wecanexperiencestressanytimewefeelwedon’thave【B1】______.Itcancomefromafeelingthatwecan’tdoanythingabout.
最新回复
(
0
)