首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
文件IN.DAT中存有200个四位整型数,函数ReadDa—ta()负责将IN.DAT中的数读到数组inBuf[]中。请编写函数findValue(),其功能是:求出千位数上的数减百位数上的数减十位数上的数减个位数上的数大于零的数,按照从小到大的顺序存人数
文件IN.DAT中存有200个四位整型数,函数ReadDa—ta()负责将IN.DAT中的数读到数组inBuf[]中。请编写函数findValue(),其功能是:求出千位数上的数减百位数上的数减十位数上的数减个位数上的数大于零的数,按照从小到大的顺序存人数
admin
2021-06-16
123
问题
文件IN.DAT中存有200个四位整型数,函数ReadDa—ta()负责将IN.DAT中的数读到数组inBuf[]中。请编写函数findValue(),其功能是:求出千位数上的数减百位数上的数减十位数上的数减个位数上的数大于零的数,按照从小到大的顺序存人数组outBuf[]中,并用count记录下符合条件的数的个数。函数WriteData()负责将outBuf[]中的数输出到文件OUT.DAT中并且在屏幕上显示出来。
注意:部分源程序已给出。
程序中已定义数组:inBuf[NUM],outBuf[NUM],已定义变量:count。
请勿改动主函数main()、读函数ReadData()和写函数WriteData()的内容。
试题程序:
#include
#define NUM 200
int inBuf[NUM],outBuf[NUM],count=0;
void ReadData();
void WriteData();
void findValue()
{
}
void main()
{
int i;
ReadData();
findValue();
WriteData();
printf(“count=%d\n”,coun1);
for(i=0;i
printf(“outBuf[%d]=%d\n”,i,outBuf
);
}
void ReadData()
{
FILE*fp;
int 1;
fp=fopen(“IN.DAT”,“r”);
for(i=0;i
fscanf(fp,“%d,”,&inBuf
);
fclose(fp);
}
void WriteData()
{
FILE*fp;
int i;
fp=fopen(“OUT.DAT”,“W”);
fprintf(fp,“count=%d\n”,count);
for(i=0;i
fprintf(fp,“%d,\n”,outBuf
);
fclose(fp);
}
选项
答案
void findValue() { int i,j,k,d[4],temp; for(i=0;i
0) { outBuf[count]=inBuf[i]; count++; } } for(i=0;i
outBuf[j]) /*如果第i位比它后面的数大,则将两者进 行交换,也即将更小的值放到第i位*/ { temp=outBuf[i]; omBuf[i]=outBuf[j]; outBuf[j]=temp; } }
解析
本题主要考查数位分解及排序。
数位分解就是将n位数上各个数位上的数值单独分离出来。解决此问题的方法是;将n位数对10求余可以将个位上的数值分离出来。将这个n位教除以10以后得到一个n-1位数,则此时n位数原来的十位就变成了n-1位数的个位.再将此n-1位数对10求余便可得到原n位数的十位。依此类推,按照同样的方法便可将n位数各个数位上的数值分离出来。
程序步骤:①将数值送入temp中。②由temp%10得到个位教f(temp/10)%10得到十位数……如此可得到各位上的数值。③按照题目所给的条件选出数据。④对选出的数据进行排序,排序的思想是(以从小到大为例):将当前数据与其后的各个数据相比较,如果当前的数据比其后的教据大,则将两数据进行交换。从而使得前面的数据小于后面的数据,达到从小到大排序的目的。
转载请注明原文地址:https://kaotiyun.com/show/BMOZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
下列关于CiscoAironet1100进入快速配置步骤的描述中,错误的是()。
封禁ICMP协议,只转发212.78.170.166/27所在子网的所有站点的ICMP数据包,正确的access.list配置是()。
根据下图所示网络结构回答下列问题。如果将59.67.33.128/25划分3个子网,其中第1个子网能容纳58台主机,后两个子网分别能容纳26台主机,要求网络地址从小到大依次分配给3个子网,这3个子网的掩码分别为__________、_________
下列关于Serv—UFTP服务器配置的描述中,正确的是()。
下列关于Windows2003系统WWW服务器的描述中,正确的是()。
将Cisc06500第4模块第1端口的通信方式设置为半双工,第2-24端口的通信方式设置为全双工,以下交换机的端口配置,正确的是()。
下列关于IPS的描述中,错误的是()。
请根据下图所示网络结构回答下列问题。如果需要IP地址为59.67.151.128的主机使用第三方软件监控路由器RG的运行状态,请写出路由器RG必须支持的协议名称。
ITU标准OC-12和OC-3的传输速率分别为()。
随机试题
桑代克认为学习的进程是一种渐进的、盲目的、______的过程。
依据《环境影响评价工程师职业资格登记管理暂行办法》关于环境影响评价工程师职业资格登记、再次登记和变更登记的规定,下列说法中正确的有()。
根据物权法律制度的规定,下列各项中,不能设定权利质押的是()。
农历新年开始有固定的时间始于()。
阅读下列材料,回答相关问题。新课改提出每一个学生都要以愉快的心情去学习生动有趣的化学,激励学生积极探究化学变化的奥秘。使他们都能具备社会所必需的化学基础知识、技能、方法和态度,并且从已有的经验出发,了解化学与日常生活的密切关系,逐步学会分析和解决
根据党政机关公文格式的有关标准,下列关于公文页码编排不正确的是()。
下列依次填入横线处的词语,恰当的一组是____。(1)进入这个单位后,他勤奋工作,每次都保质保量地完成任务,很快就得到领导及同事的____。(2)由于父亲是美国人,母亲是韩国人,比起其他同年龄的中学生来说,她很难自我____。
多边政策
设φ1(x),φ2(x),φ3(x)为二阶非齐次线性方程y’’+a1(x)y’+a2(x)y=f(x)的三个线性无关解,则该方程的通解为().
某车间需要用一台车床和一台铣床加A、B、C、D4个零件。每个零件都需要先用车床加工,再用铣床加工。车床与铣床加工每个零件所需的工时(包括加工前的准备时间以及加工后的处理时间)如下表:若以A、B、C、D零件顺序安排加工,则共需32小时。适当调整零件加工顺
最新回复
(
0
)