首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知数据文件IN85.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组9中,请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加十位数字上的值恰好等于百位数字上的值加上个位数字上的值,并且此4位数是偶数,则统计
已知数据文件IN85.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组9中,请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加十位数字上的值恰好等于百位数字上的值加上个位数字上的值,并且此4位数是偶数,则统计
admin
2010-01-09
82
问题
已知数据文件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的某用户数据库中,设有T表,现要在T表的c1列和c2列上建立一个复合唯一聚集索引,其中c1列值重复率为20%,c2列为10%。请补全下列语句建立一个性能最优的索引:CREATEuNIQUECLLISTERED
某商场商品经营管理系统使用SQLServer2008数据库管理系统,此系统上线运行1年后,业务人员使用某统计功能(此功能每月使用一次)时发现速度很慢。该统计功能主要执行的SQL语句如下:SELECT商品号,SUM(销售数量*销售价格)销售额
设在SQLServer2008某数据库中有按如下格式定义的存储过程首部:CREATEPROCP1@xint,@yint,@zintoutputAS…请补全下列调用该存储过程的语句。DECLARE@SintExECP12
在SQLServer2008中,设log1是SQLServer身份验证模式的数据库服务器登录帐户。现要授予log1具有创建数据库的权限,请补全下列语句:EXECsp_addsrvrolemember′log1′,′【9】′
以下关于两段锁协议的原理叙述错误的是()。
在SQLServer2008中,某数据库用户User在此数据库中具有对于表数据的查询和更改权限。现要收回User对于T表的数据更改权,下述是实现该功能的语句,请补全该语句。【8】UPDATEONTFROMUser。
在SQLServer2008中,通过在视图上创建唯一【8】索引的方式可使视图的结果集保存到数据库中。
在建立数据仓库的数据集成工作中,需要采用适当的策略从数据源获取变化数据。下列数据表中,一般情况下不适宜采用快照方式从业务系统获取数据的是()。
某网上书店根据用户的历史购书记录,采用某种数据挖掘算法分析出用户最可能属于某一类书的爱好者,应该采用()。
下面程序段的功能是:在数据库中判断是否存在名为my_proc的存储过程,若存在,则删除之,然后创建同名的存储过程,该存储过程的功能是向author_id、author_name和addtess字段插入数据。阅读并回答以下问题:USEbookdb
随机试题
无效合同的认定单位是( )。
施工合同履行中,总包单位将土方开挖分包给了甲分包商,将基础部分分包给了乙分包商,但是甲分包商工期延误,现场又有监理单位,乙分包商为此应向()提出要求承担违约责任。
会计人员工作交接的意义在于()。
田某,现年16岁,一天她到当地百货大楼以600元的价格为自己购买了一条项链。回家后被其父发现。并要求百货大楼退款,田某则称,自己虽仍上中学,但已经有自理能力,因而拒绝退回项链。问题:(1)田某的买卖行为是否已经生效?(2)田某的父亲要求
作为一种力量,文化力不是一种直接作用的力,其显现及发挥必然要通过一定的载体或媒介。要么是附着于人们的思想观念或是精神理念上,要么是物化在一定的物质产品或精神产品上。只有通过精神的或者物质的载体,文化力才有了真实的存在。也就是说,文化力并不是那种立竿见影式的
间歇训练法是发展无氧耐力的重要训练方法。
在2×2的实验设计中,研究的因素有()
20世纪50年代初,中国提出“和平共处五项原则”的主要目的是()
Hehastoldmewhentheyaretodiscussmyproposal.
西方人很早就把中国和瓷器(porcelain)联系在一起,这是因为制瓷技术是中国人发明的,瓷器是从陶器发展来的,如果从生产原始瓷器的商代算起,中国的瓷器大约有3000多年的历史了。中国的制瓷技术从东汉以来发展很快,各个历史时期都出现了别具特色的制作瓷器的名
最新回复
(
0
)