首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知数据文件IN89.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加个位数字上的值恰好等于百位数字上的值加上十位数字上的值,并且此4位数是奇数,则统计
已知数据文件IN89.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加个位数字上的值恰好等于百位数字上的值加上十位数字上的值,并且此4位数是奇数,则统计
admin
2010-01-09
36
问题
已知数据文件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://kaotiyun.com/show/YOYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在数据库动态转储机制中,一般需要使用【12】文件才能将数据库恢复到某一时刻的正确状态。
设在SQLServer2008中,要创建有一个输入参数和一个输出参数的存储过程。请补全下列语句:CREATEPROCP1@xint,@yint【7】AS……
某商场商品经营管理系统使用SQLServer2008数据库管理系统,此系统上线运行1年后,业务人员使用某统计功能(此功能每月使用一次)时发现速度很慢。该统计功能主要执行的SQL语句如下:SELECT商品号,SUM(销售数量*销售价格)销售额
设某连锁商店数据库中有关系模式R:R(商店编号,商品编号,库存数量,部门编号,负责人)如果规定:每个商店的每种商品只在一个部门销售,每个商店的每个部门只有一个负责人,每个商店的每种商品只有一个库存数量。请根据上述规定,写出关系模式R的函数依赖集。
设在SQLServer2008某数据库中有购买表(顾客号,商品号,购买时间),现要查询C02顾客购买过但C01顾客没有购买过的商品。请补全下列语句。SELECT商品号FROM购买表WHERE顾客号=′C02′【5】SELECT商品号
数据库应用系统在使用过程中,会根据用户的需求及系统运行情况对系统进行升级和改造。关于系统升级改造工作,下列说法错误的是()。
索引是数据库中重要的数据结构,关于索引现有下列说法:Ⅰ.在某个查询中带排序的属性有多个时可以考虑在这些属性上建立复合索引Ⅱ.一个表中最多只能有一个主索引或聚集索引Ⅲ.多属性索引中,索引属性的顺序一般按照属性的长度进行排列
下面关于模式分解的说法,错误的是()。
下图所示的简单互联网中,路由器Q的路由表中对应目的网络40.0.0.0的下一跳步IP地址应为【】。
电子商务中的数字签名通常利用公开密钥加密方法实现,其中发送者签名使用的密钥为发送者的 【】。
随机试题
多器官功能障碍综合征(MODS)特点有
谈论美味佳肴时引起唾液分泌是
关于局部神经元回路,不正确的论述是
肝硬化患者机体多种功能受到影响,出现低血糖的主要原因是
关于高桩码头工程岸坡抛填施工时的说法,正确的是()。
“运输工具名称及号码”:SUNSEA/407E。()
定置管理的开展程序是()。
在人人都有发言权的微博时代,一个不经意的转发和评论,既可能为真相增添力量,也可能不小心成为谣言的帮闲,甚至可能成为他人的灾难。该如何更好地行使自己的话语权,这是一个值得认真对待的问题。近日《中国青年报》有篇文章谈到,一旦被主观偏见、愤怒情绪、不假思索的责骂
我国科研人员经过对动物和临床的多次试验,发现中药山茱萸具有抗移植免疫排斥反应和治疗自身免疫疾病的作用,是新的高效低毒免疫抑制剂。某医学杂志首次发表了关于这一成果的论文。多少有些遗憾的是,从杂志收到该论文到它的发表,间隔了6周。如果这一论文能尽早发表的话,这
It’spartofthenewyearritual—anannualattempttostartafreshandturnoveranewleaf.Butmakingresolutionsisanearpo
最新回复
(
0
)