首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件in70.dat中存有若干个(个数
已知在文件in70.dat中存有若干个(个数
admin
2010-01-09
11
问题
已知在文件in70.dat中存有若干个(个数<200)4位数字的正整数,函数ReadDat()是读取这若干个正整数并存入数组xx中。请编制函数CalValue(),其功能要求是:(1)求出这个文件中共有多少个正整数totNum。 (2)求这些数右移一位后,产生的新数是奇数的数的个数totCnt,以及满足此条件的这些数(右移前的值)的算术平均值totPjz。最后调用函数WriteDat()把所有结果输出到文件out70.dat中。
注意:部分源程序己给出。
请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
试题程序:
#include<stdio. h>
#include<conio. h>
#define MAXNUM 200
iht xx [MAXNUM];
int totNum=0;
int totCnt=0;
double totPjz=0.0;
int ReadDat (void);
void WriteDat(void);
void CalValue(void)
{
}
void main()
{
int i;
clrscr ( );
for ( i=0; i xx
=0;
if (ReadDat ())
{
printf ("数据文件IN70.DAT不能打开! \007\n");
return;
}
CalValue ();
printf ("文件IN70. DAT中共有正整数=%d个\n", totNum);
printf ("符合条件的正整数的个数=%d个\n", totCnt);
printf ("平均值=%. 21f\n", totPj z);
WriteDat ();
int ReadDat (void)
{
FILE *fp;
iht i=0;
if ( (fp=fopen ("IN70 .DAT", "r") )==NULL) return 1;
while ( ! feof (fp))
{
fscanf (fp, "%d", &xx [i++] );
}
fclose (fp);
return 0;
}
void WriteDat(void)
{
FILE *fp;
fp=fopen ("OUT70. DAT", "w");
fprintf (fp, "%d\n%d\n%. 21f\n",totNum, totCnt, totPjz);
fclose (fp);
}
选项
答案
void CalValue (void) { int i, data; for (i=0; i { if(!xx[i]) break; /*如果数为0,则表示数组存的数已经结束,退出循环*/ if (xx [i] >0) totNum++; /*统计正整数的个数*/ data=xx [i] >>1; /*将数右移一位*/ if(data % 2) /*如果产生的新数是奇数*/ { totCnt++; /*统计满面足条件的数的个数*/ totPj z+=xx [i]; /*求满足条件的数的总和*/ } } totPj z/=totCnt; /*求满足条件的数的平均值*/
解析
本题考查的知识点如下:
(1)右移运算符“>>”的使用。
(2)数组结束的判断和强行退出一层循环结构。
(3)特殊运算符“%”的使用。
在本题中,并没有给出确切的数据个数,足以数据的最大个数定义的数组。在主函数中,给所有的数组成员赋初值为0,而从文件中读取得数据是正整数,所以只要数组的某个元素为0,则说明数组存的数据已经结束。此时就可以结束循环结构。这里要使用右移运算符实现数据的右移位,右移运算符是双目运算符。运算符左侧是要移的数据,右侧是移动的位数。右侧移出的数据(低位数据)舍弃。1个数除以2取余所得的数是1,则这个数足奇数。
转载请注明原文地址:https://kaotiyun.com/show/OOYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
在数据库系统中,【4】映像关系用于提供数据与应用程序间的逻辑独立性。
两阶段加锁协议可以保证事务调度的【11】性。
设有学生表(学号,姓名,所在系)和选课表(学号,课程号,成绩),现要利用开窗函数查询每个学生的姓名、所在系及选课门数(不包括没选课的学生)。请补全下列语句:SELECTDISTINCT姓名,所在系,COuNT(*)【4】As选课门数FROM学生
在SQLServer2008中,某数据库用户User在此数据库中具有对于表数据的查询和更改权限。现要收回User对于T表的数据更改权,下述是实现该功能的语句,请补全该语句。【8】UPDATEONTFROMUser。
触发器有3种类型,即INSERT类型、UPDATE类型和【4】。
如果数据文件中数据记录排列顺序与索引文件中索引项的排列顺序一致,则此种索引被称为【1】索引。
设有高校选课系统,需要对学校的系信息、教师信息、课程信息、学生信息、学生选课信息进行管理。已知系(DEPT)信息包括系编号(DeptNO)、系名称(DeptName);教师(Teacher)信息包括教师号(TNO)、教师名(Tname);课程(Course
设在SQLServer2008某数据库中有商品表和销售表,两个表的定义如下:CREATETABLE商品表(商品号char(10)PRIMARYKEY,商品名varchar(40),类别varchar(20),进货单价int);
关于分布式数据库系统的体系结构及相关技术,下列说法正确的是()。
设有商场数据库应用系统,在系统生命周期中,可能会遇到下列故障:Ⅰ.某DBA违反规定使用数据库服务器上公网后,服务器操作系统遭到攻击,导致系统死机后不得不重启Ⅱ.与几台POS机相连的交换机突然损坏,导致这几台POS机无法提供服务Ⅲ.系统运行过程中突然停
随机试题
审美体验的独特性就在于()
A.风水B.皮水C.阳水D.阴水若遍身肿,烦渴,小便赤涩,大便闭。此属
组成头颅的骨骼有
目前国内建筑工程设计项目用地竖向规划时常用的、统一的水准高程系统是:[2008-17,2003-10]Ⅰ.56黄海高程系统基准Ⅱ.85高程基准Ⅲ.吴淞高程基准Ⅳ.珠江高程基准Ⅴ.75渤海高程基准
从事市政公用工程压力管道焊接的焊工,必须持有有关部门统一印制的《特种设备作业人员证》,并在有效期内,该有关部门是指()。
投资者实际投入的金额超过投资者在企业注册资本中所占份额的部分,应记入()账户。
根据《个人信用信息基础数据库管理暂行办法》的规定,商业银行在()时,才可查看个人的信用报告。
工作说明书是通过工作岗位分析制定出来的人力资源管理文件,工作岗位分析是()等项活动的总称。
从报纸到咖啡馆再到美国式的大型购物中心,科威特对这个几乎单枪匹马把他们从伊拉克军事占领之下救出来的国家抱有恶感。在首都科威特整洁的街道上,人们纷纷猜测说,华盛顿宁愿萨达姆.侯赛因继续执政,以保证科威特及其弱小的邻国能牢牢地置于美国的控制之下。最符合上述文字
A、Candiesandtoys.B、Clothesandgifts.C、Ridesandshows.D、Ridesandfoods.C短义捉到在父母们看工艺品时,工艺展销会给小孩提供游戏和表演,故选C。A在短文中没有提及;B是人们
最新回复
(
0
)