首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知数据文件IN89.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加个位数字上的值恰好等于百位数字上的值加上十位数字上的值,并且此4位数是奇数,则统计
已知数据文件IN89.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制一函数jsVal(),其功能是:如果一个4位数的千位数字上的值加个位数字上的值恰好等于百位数字上的值加上十位数字上的值,并且此4位数是奇数,则统计
admin
2010-01-09
40
问题
已知数据文件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://jikaoti.com/ti/pYp7FFFM
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在SQLServer2008中,能够出现在SELECT语句目标列中的用户自定义函数是【5】函数。
设在SQLServer2008中,有如下定义的存储过程:CREATEPROCP1@deptvarhcar(30)=′计算机系′,@xintAS……现要调用该存储过程,并且第一个参数用存储过程的默认值。请补全下列语句:EXECP1【
在SQLServer2008中,计算两个日期之差的函数是_______。
数据库管理系统中的加锁协议规定了事务的加锁时间、持锁时间和释放锁时间,其中____________协议可以完全保证并发事务数据的一致性。
现有课程表(课程号,课程名,学分,开课学期,课程性质),课程号为主码。该表数据量较大。设经常要对该表执行类似下面的查询:SELECT、*FROM课程表WHERE课程名=′数据库原理′为提高这类查询的执行效率,下列物理设计方案中,正确且最为合理的是(
在SQLServer2008中,计算两个日期之差的函数是________。
在概念模型中,属性用于描述事物的特征或性质。关于属性有下列说法:Ⅰ.一个实体集中的属性名要唯一Ⅱ.属性一般用名词或名词短语命名Ⅲ.一个属性的值可以取自不同的域Ⅳ.实体集的标识属性能够唯一识别实体集中每一个实体
下面说法正确的是()。
设有职工表(职工号,姓名,地址1,地址2),其中,职工号为主码。现要求地址1和地址2组合起来不能有重复值。在SQLServer2008环境中有下列创建该表的语句:Ⅰ.CREATETABLE职工表(职工号intPRIMARYKEY,姓名nch
下列叙述中不属于三层B/S结构数据库应用系统特点和操作特征的是()。
随机试题
下列说法错误的是()。
男,27岁,间歇性右下腹痛伴腹泻2年。呕吐3天,为宿食,无大便。体温37.4℃,消瘦、贫血,右下腹可扪及一腹块,可见肠形,并闻及气过水音及高调肠鸣音。血清癌胚抗原CEA(-)。最可能的诊断为
原发性肝癌病人最突出的体征是
A.有医学专业本科学历,在保健机构试用期满6个月B.有医学专业本科学历,在医疗机构试用期满1年C.有医学专业专科学历,取得执业助理医师执业证书后,在预防机构工作满1年D.有医学专业本科学历,在医疗机构中试用期满6个月E.有医学专科学历,在预防机构试
[2005年第36题]有两种理想气体,第一种的压强记作p1,体积记作V1,温度记作T1,总质量记作m1,摩尔质量记作M1:第二种的压强记作p2,体积记作V2,温度记作T2,总质量记作m2,摩尔质量记作M2。当V1=V2,T1=T2,m1=m2时,则为
从价税和从量税的划分标准为( )。
实行多样化经营的原因不包括()。
工厂加工某种零件,经测定,单独加工完成这种零件,甲车床需用x小时,乙车床需用(x2一1)小时,丙车床需用(2x一2)小时。若甲车床用时是丙车床的,从早上8点开始,甲、乙、丙三车床轮流开工,每次开工1小时,12:00一13:30为午休时间不开工。则预计几点能
设X为随机变量,若矩阵的特征值全为实数的概率为0.5,则().
Wedon’tdoubt______hecandoagoodjob.
最新回复
(
0
)