首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知数据文件IN89.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加个位数字上的值恰好等于百位数字上的值加上十位数字上的值,并且此4位数是奇数,则统计
已知数据文件IN89.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加个位数字上的值恰好等于百位数字上的值加上十位数字上的值,并且此4位数是奇数,则统计
admin
2010-01-09
72
问题
已知数据文件IN89.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加个位数字上的值恰好等于百位数字上的值加上十位数字上的值,并且此4位数是奇数,则统计出满足此条件的数的个数cnt并把这些4位数按从小到大的顺序存入数组b中,最后调用写函数writeDat()把结果cnt以及数组b中符个条件的4位数输出到OUT89.DAT文件中。
注意:部分源程序已给出。
程序中已定义数组:a[200],b[200],已定义变量:cnt。
请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。
试题程序:
#include<stdio.h>
#define MAX200
int a[MAX],b[MAX],cnt=0;
void jsVal()
{
}
void readDat ()
{
int i;
FILE *fp;
fp=fopen("IN89.DAT","r");
for (i=0; i<MAX; i++)
fscanf(fp,"%d",&a
);
fclese(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 ("OUT89.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+data==hun+ten) && a[i]%2==1) /*如果千位数加个位数等于百位数加十位数,并且此数是奇数*/ { b[cnt]=a[i];/*则将满足条件的数存入数组b中*/ cnt++;/*统计满足条件的数的个数*/ } } for (i=0; i<cnt-1; i++) /*将数组b中的数按从小到大的顺序排列*/ for (j=i+1; j<cnt; j++) if(b[i]>b[j]) { data=b [i]; b [i]=b [j]; b [j] =data; } }
解析
本题考查的知识点如下:
(1)运算符“%”及“/”的使用。
(2)选择结构中多个条件的布匀;运算。
(3)数据的排序。
在本题中,首先要将一个4位数的千位、百位、十位、个位拆成独立的数字。这里借助特殊运算符号“%”(取余)和“/”(整除),拆分方法略。一个数除以2取余所得的数为1,则这个数是奇数。题中给出的两个条件必须同时满足,所以两条件之间用“与”运算。将符合条件的数先存入数组b中,再对b中的数据进行排序。排序使用“选择排序法”。
转载请注明原文地址:https://www.kaotiyun.com/show/YOYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在SQLServer2008中,若希望数据库用户ACCT具有创建数据库对象的权限,较为适合的实现方法是()。
在进行某学校教务管理系统的数据库设计时,数据库设计人员设计了如下几个关系模式:系(系号,系名),系号为主码学生(学号,姓名,所在系号),学号为主码课程(课程号,课程名,开课系号),课程号为主码选课(学号,课程号,选课
数据转储也被称为数据备份,是数据库管理员的重要工作。下列有关此项工作的说法,正确的是()。
【10】视图是包含查询结果的数据库对象,其数据不是在视图使用时才读取而是预先计算的。
在SQLServer2008中,要授予某数据库中的某个用户具有该数据库中全部用户数据表的插入、删除和修改权限,比较合理的做法是将该用户添加到系统提供的【6】数据库角色中。
设某超市经营管理系统使用SQLServer2008数据库管理系统,此数据库服务器有2颗CPU、16GB内存、2TB磁盘。上线运行1年后,用户在生成每天每个销售人员及每个收银台的总销售额报表时速度缓慢。经技术人员分析,发现速度缓慢的原因为销售单据表和销售
在数据仓库设计和建设过程中,设计者需要调查用户的决策或数据处理需求,并将功能相近且需要相关联数据支持的需求进行归类,得到不同的需求集合,并在企业数据模型中寻找能够满足各个需求集合的数据集合,然后针对各个数据集合开展数据仓库数据模型的设计。这种设计方法称为_
在一台正在运行的SQLServer2008中,现需使用复制数据库文件的方法将某数据库从一台服务器移动到另一台服务器。关于复制数据库文件,有下列实现方法:Ⅰ.首先从数据库服务器中分离出要复制的数据库,然后复制数据库文件Ⅱ.首先停止SQLServer
数据库管理系统中的加锁协议规定了事务的加锁时间、持锁时间和释放锁时间,其中_______协议可以完全保证并发事务数据的一致性。
关系模型是数据库系统最常用的一种数据模型。下列关于关系模型的说法,错误的是()。
随机试题
当排气压力超过高压压力调定值时,压力控制器动作,造成()。
男性,60岁,阵发性腹痛伴频繁呕吐.停止排气、排便8小时入院。2年前因十二指肠溃疡穿孔行胃大部切除术,查体:腹稍胀,上腹部压痛。患者入院次日腹痛加剧,体温38.9℃,查体:腹部有明显的肌紧张和反跳痛,白细胞16×109/L。此时最恰当的治疗方案是
A.普萘洛尔B.硝苯地平C.哌唑嗪D.可乐定E.硝普钠α1受体阻断剂()。
为膝关节化脓性关节炎患者选择的固定位置为
所有会计凭证都要经过会计部门有关人员进行严格审核,经过审核无误的会计凭证才能作为交易或事项发生、完成情况的证明和登记账簿的依据。()
发行可转换公司债券的上市公司最近3个会计年度实现的年均可分配利润不少于()。
企业溢价发行股票发生的相关手续费、佣金等交易费用,应计入财务费用。()
某公司是一家大型的家用电器公司,人力资源部张经理正在召开一个专题工作会议,参加者包括公司招聘专员、助理和各个下属分厂劳动人事部负责人等。大家在分析2012年上半年各类员工流动率时,发现去年通过外部招募来的员工,包括一些管理和技术人才的流失率都很高,而内部招
2008年.第三产业增加值的同比增长率最快的两个城市的增加值之和约比最慢的两个城市之和()。
事物发展过程中的部分质变是指
最新回复
(
0
)