首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知数据文件IN45.DAT中存有200个4位数,并已调用读函数IeadDat()把这些数存入数组a中,请编制一函数isVa1(),其功能是:把千位数字和十位数字重新组合成一个新的十位数ab(新十位数的十位数字是原4位数的千位数字,新十位数的个位数字是原4
已知数据文件IN45.DAT中存有200个4位数,并已调用读函数IeadDat()把这些数存入数组a中,请编制一函数isVa1(),其功能是:把千位数字和十位数字重新组合成一个新的十位数ab(新十位数的十位数字是原4位数的千位数字,新十位数的个位数字是原4
admin
2009-02-24
16
问题
已知数据文件IN45.DAT中存有200个4位数,并已调用读函数IeadDat()把这些数存入数组a中,请编制一函数isVa1(),其功能是:把千位数字和十位数字重新组合成一个新的十位数ab(新十位数的十位数字是原4位数的千位数字,新十位数的个位数字是原4位数的十位数字),以及把个位数和百位数组成另一个新的十位数cd(新十位数的十位数字是原4位数的个位数字,新十位数的个位数字是原4位数的百位数字),如果新组成的两个十位数ab-ed≥10且ab-cd≤20且两个数均为偶数,同时两个新十位数字均不为零,则将满足此条件的4位数按从大到小的顺序存入数组b中,并要计算满足上述条件的4位数的个数ent,最后调用写函数writeDat()把结果cnt及数组b中符合条件的4位数输出到OUT45.DAT文件中。
注意:部分源程序已给出。
程序中已定义数组:a[200],b[200],已定义变量:cnt。
请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。
试题程序;
#include<stdio. h>
#define MAX 200
int a[MAX] ,b[MAX] ,cnt=0;
void jsVal( )
{
}
void readDat( )
{
int i;
FILE *fp;
fp=fopen ( "IN45. DAT", "r" );
for (i=0; i<MAX; i++)
fscanf (fp, "%d", &a Iii );
fclose (fp);
}
main ( )
{
int i;
readDat();
jsVal();
printf ("满足条件的数=%d\n", cnt );
for(i=0;i<cnt;i++)
printf("%d\n",b
);
printf("\n");
writeDat();
}
writeDat()
{
FILE *fp;
int i;
fp=fopen("OUT45.DAT","w");
fprintf(fp,"%d\n",cnt);
for(i=0;i<cnt;i++)
fprintf(fp, "%d\n",b
);
fclose(fp);
}
选项
答案
void jsVal( ) { int i, thou, hun, ten, data, j; int ab, cd; for (i=O; i<200; i++) { thou=a [i]/1000; /*求四位数的千位数字*/ hun=a [i] %1000/100; /*求四位数的百位数字*/ ten=a [i] %100/10; /*求四位数的十位数字*/ data=a [i] %10; /*求四位数的个位数字*/ ab=thou*lO+ten; /* ab的十位数字是原4位数的千位数字,个位数字是原4位数的十位数字*/ cd=data*lO+hun; /* cd的十位数字是原4位数的个位数字,个位数字是原4位数的百位数字*/ if ((ab-cd>=lO) && (ab-cd<=20) && (ab%2==O) && (cd%2==O) &&ab ! =O&&cd ! =0 ) { /*如果-ab-cd≥10且ab-od≤20且两个数均为偶数,且均不为零*/ b[cnt] =a [i]; /*将满足条件的数存入数组b中*/ cnt++; /*统计满足条件的数的个数*/ } } for (i=O; i<cnt-1; i++) /*将数组b中的4位数按从大到小的顺序*/ for (j=i+l; j<cnt; j++) if(b[i]<b[j]) { data=b [i]; b[i]=b[j]; b [j ] =data; } }
解析
本题考查的知识点如下:
(1)将一个4位整数各位上的数转变成单独的个位数。
(2)判断结构中多个条件的布尔运算。
(3)循环的使用。
(4)数据的排序。
在本题中,首先要将一个4位数的千位、百位、十位、个位拆成独立的数字。这里借助特殊运算符号“%” (取余)和“/” (整除)。将一个4位数整除1000则可得到其干位上的数字,除以1000取余再整除 100则可得百位上的数字,除以100取余再整除10则可得十位上的数字,除以10取余则得个位上的数字。若一个数除以2取余为0,则这个数是偶数。题目中所给的条件必须同时满足,所以各条件之间用“与”运算。最后的排序采用“选择排序法”。
转载请注明原文地址:https://www.kaotiyun.com/show/0RYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
下列不是数据字典存储的信息的是
广义表是线性表的推广,是由零个或多个单元素或______所组成的有限序列。
在DBMS中建立DBMS的系统缓冲区,系统工作区,打开数据字典的工作在【】程序模块中完成。
在文件系统中,文件的逻辑结构可分为两类,它们是【】文件和记录式文件。
下列哪一个术语与数据的存储结构无关?
下列各种中断中,()是强迫性中断。Ⅰ、硬件故障中断Ⅱ、访管中断Ⅲ、输入|输出中断Ⅳ、缺页中断Ⅴ、地址越界中断
下列条目中哪些是IBM商务智能解决方案的组成部分?Ⅰ.OLTP业务系统Ⅱ.前台分析工具Ⅲ.数据仓库管理器Ⅳ.多维服务器
从WWW的资源和行为中抽取感兴趣的、有用的模式或隐含的信息的过程,称为【】挖掘。
下面关于数据存储方式的叙述中,不止确的是
A、 B、 C、 D、 C最坏适应算法是根据申请,在空闲区表中选择能满足申请要求的最大的空闲区。该算法的出发点是:在大空间区中装入信息后,分割剩下的空闲区相对也大,还能用于装入新的信息。该算法的优点是可以避免
随机试题
关于“春秋决狱”,下列说法错误的是
下列各类骨折中最可能引起呼吸困难的是
对民法上的物权可以按不同的标准加以分类,其中地上权属于()。
下列洗钱各个阶段中,最容易被侦察到的阶段是()。
梨状隐窝位于()。
根据下表的数据回答下面问题。
甲:那座拱形桥是什么时候被什么人炸毁的?乙:是被日本人炸的,我记得那是抗日战争快结束的时候。以上对话中的预设是()Ⅰ.曾经有一座拱形桥。Ⅱ.拱形桥被人炸毁了。Ⅲ.有一段历史时期被称作抗日战争
项目沟通中不恰当的做法是______。
TheEnglishPubVocabularyandExpressionstaverndartsboardontaphardtackalehousepooltable
Whyyoushouldn’ttrytobeamorningpersonA)We’veallhearditbefore:tobesuccessful,getoutofbedearly.Afterall,
最新回复
(
0
)