首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知数据文件IN85.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组9中,请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加十位数字上的值恰好等于百位数字上的值加上个位数字上的值,并且此4位数是偶数,则统计
已知数据文件IN85.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组9中,请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加十位数字上的值恰好等于百位数字上的值加上个位数字上的值,并且此4位数是偶数,则统计
admin
2010-01-09
60
问题
已知数据文件IN85.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组9中,请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加十位数字上的值恰好等于百位数字上的值加上个位数字上的值,并且此4位数是偶数,则统计出满足此条件的数的个数cnt并把这些4位数按从小到大的顺序存入数组b中,最后调用写函数writeDat()把结果cnt及数组b中符合条件的4位数输出到OUT85.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("IN85.DAT","r");
for(i=0;i<MAX;i++)
fscanf(fp,"%d",&a
);
fclose(fp);
}
main ()
{
int i;
readDat ();
jsVal ();
printf ("满足条件的数=%d\n", cnt);
for(i=0;i<cnt;i++)
printf("%d",b
);
printf ("\n");
writeDat();
}
writeDat ()
{
FILE *fp;
int i;
fp=fopen ("OUT85.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; for (i=0; i<200; i++) { thou=a [i]/1000; /*求四位数的千位数字*/ hun=a [i] %1000/100; /*求四位数的百位数字*/ ten=a [i] %100/10; /*求四位数的十位数字*/ data=a [i] %10; /*求四位数的个位数字*/ if(thou+ten==hun+data && a[i]%2!=1) { /*如果千位数加十位数等于百位数加上个位数,并且此数是偶数*/ b[cnt]=a[i]; /*则将满足条件的数存入数组b中*/ cnt++; /*统计满足条件的数的个数*/ } } for (i=0; i<cnt-1; i++) /*将数组b中的数按小到大的顺序排列*/ for (j=i+l; j<cnt; j++) if(b[i]>b[j]) { data=b [i]; b [i] =b [j]; b [j] =data; } }
解析
本题考查的知识点如下:
(1)运算符“%”及“/”的使用。
(2)选择结构中多个条件的布尔运算。
(3)数据的排序。
在本题中,首先要将一个4位数的千位、百位、十位、个位拆成独立的数字。这里借助特殊运算符号“%”(取余)和“/”(整除),拆分方法略。题中给出的两个条件必须同时满足,所以两条件之间用“与”运算。将符合条件的数先存入数组b中,再对b中的数据进行排序。排序使用“选择排序法”。
转载请注明原文地址:https://kaotiyun.com/show/bKYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在SQLServer2008中,设某数据库中有商品表(商品号,商品名,进货价格),商品号为主码;销售表(商品号,销售时间,销售数量,销售价格,本次利润),商品号和销售时间为主码,销售价格为本次销售商品的单价。现要求每当在销售表中插入前4列数据时(假设一
某书店采用了SQLServer2008数据库管理系统,该书店有一个需求,需要统计指定年份中每一本书的销售总额,例如:查询2012年所有书的销售总额。已知图书结构如下:图书表(书号BOOK_ID,书名BOOK_NAME,单价BOOK_
某商场商品经营管理系统使用SQLServer2008数据库管理系统,此系统上线运行1年后,业务人员使用某统计功能(此功能每月使用一次)时发现速度很慢。该统计功能主要执行的SQL语句如下:SELECT商品号,SUM(销售数量*销售价格)销售额
假定我们要建立一个航空数据库,存储如下信息:每个机场有机场编号、所在城市;每个航班有航班编号、起飞时间、飞行时间;飞机有飞机编号、型号、载客人数;飞行员有飞行员编号、姓名;每个航班有唯一的起飞机场和降落机场,每个机场会有多个航班起降每架飞机可飞
数据库应用系统在使用过程中,会根据用户的需求及系统运行情况对系统进行升级和改造。关于系统升级改造工作,下列说法错误的是()。
在SQLServer2008中,计算两个日期之差的函数是_______。
设用UML设计某数据库应用系统,设计人员规划了一组应用程序集,该集合由动态链接库和可执行程序构成。为了展现这些应用程序集间的组织和依赖关系,以对源代码、可执行程序的发布等进行系统建模,应采用的UML图是_______图。
下列关于概念数据模型的说法,错误的是()
设有商场数据库应用系统,在系统生命周期中,可能会遇到下列故障:Ⅰ.某DBA违反规定使用数据库服务器上公网后,服务器操作系统遭到攻击,导致系统死机后不得不重启Ⅱ.与几台POS机相连的交换机突然损坏,导致这几台POS机无法提供服务Ⅲ.系统运行过程中突然停
下面程序段的功能是:在数据库中判断是否存在名为my_proc的存储过程,若存在,则删除之,然后创建同名的存储过程,该存储过程的功能是向author_id、author_name和addtess字段插入数据。阅读并回答以下问题:USEbookdb
随机试题
事业生涯
ProfessorTaylor’stalkhasindicatedthatsciencehasaverystrong______ontheeverydaylifeofnon-scientistsaswellass
A.口唇淡白B.口唇深红C.口唇干燥D.口唇青黑伤津液患者可见
选择氢原子核作为人体磁共振成像的原子核的理由不包括
某女,43岁。入睡困难,且多梦易醒,心悸健忘,神疲食少,四肢倦怠,腹胀便溏,面色少华,舌质淡,苔薄白,脉细无力。中医诊断为不寐。治疗宜选用的方剂是()。
组成护理程序框架的理论是
对于使用寿命不确定的无形资产,在持有期间内不需要摊销,但需要至少于每一会计期末进行减值测试;对于使用寿命有限的无形资产,会计期末不需要进行减值测试。()
在考生文件夹下打开EXCEL.XLS文件:(1)将sheet1工作表的A1:D1单元格合并为一个单元格,内容水平居中;计算职工的平均年龄置C13单元格内(数值型,保留小数点后1位);计算职称为高工、工程师和助工的人数置G5:G7单元格区域(利用COUNT
Smokingisconsidereddangeroustothehealth:Ourtobacco-sellerMr.Johnson,therefore,alwaysaskshiscustomers,iftheyare
Walking,ifyoudoitvigorouslyenough,istheoverallbestexerciseforregularphysicalactivity.Itrequiresnoequipment,e
最新回复
(
0
)