首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
已知在文件in70.dat中存有若干个(个数
已知在文件in70.dat中存有若干个(个数
admin
2010-01-09
17
问题
已知在文件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://www.kaotiyun.com/show/OOYZ777K
本试题收录于:
三级网络技术题库NCRE全国计算机三级分类
0
三级网络技术
NCRE全国计算机三级
相关试题推荐
某书店采用了SQLServer2008数据库管理系统,该书店有一个需求,需要统计指定年份中每一本书的销售总额,例如:查询2012年所有书的销售总额。已知图书结构如下:图书表(书号BOOK_ID,书名BOOK_NAME,单价BOOK_
设在SQLServer2008某数据库中有按如下格式定义的存储过程首部:CREATEPROCP1@xint,@yint,@zintoutputAS…请补全下列调用该存储过程的语句。DECLARE@SintExECP12
在企业数据仓库架构中,操作型数据存储ODS一般情况下主要用来支持即时OLAP和全局型【15】两类应用。
在进行数据库应用系统需求分析时,需要给出允许并发访问的最大用户数,这属于数据库应用系统的【1】需求分析。
下列关于分区表的说法,错误的是()。
在数据库系统中,【4】映像关系用于提供数据与应用程序间的逻辑独立性。
在进行数据库性能调优过程中,需要考虑数据库系统软件、硬件配置、网络环境等多方面因素。下列有关性能调优的说法,错误的是()。
设用UML设计某数据库应用系统,设计人员规划了一组应用程序集,该集合由动态链接库和可执行程序构成。为了展现这些应用程序集间的组织和依赖关系,以对源代码、可执行程序的发布等进行系统建模,应采用的UML图是_________图。
现有一个大型公司的数据库系统,其业务主要以更新事务为主,并且不同部门的用户访问不同的数据子集。随着用户数量的增加,出现了性能瓶颈。该公司希望采用分布式数据库技术解决该问题。下列最适合该应用的数据分配方式是()。
类图技术是面向对象方法的核心技术。下列所示的UML类图中,描述正确的是()。
随机试题
数控机床坐标轴命名原则规定,()的运动方向为该坐标轴的正方向。
A.补中益气汤B.圣愈汤C.归脾汤D.养血和血汤E.调肝汤治疗痛经肾气亏损证,应首选的方剂是
当定期检查中出现状况值为3或4的项目。且其产生原因及详细情况不明时,应做专项检查()。
有一宗工业用地,土地取得费及相关税费为15万元,为自有资金投入;土地开发费为20万元,通过银行贷款取得,贷款年利率为6%,土地开发期为1.5年。经调查,该宗地各项费用投入符合一般水平。在该土地上建一建筑物。据市场调查确定,建筑物出租每年能获得的总收益为20
甲公司为增值税一般纳税人。2×17年1月1日,甲公司库存原材料的账面余额为2500万元,账面价值为2000万元;当年购入原材料增值税专用发票注明的价款为3000万元,增值税进项税额为510万元,当年领用原材料按先进先出法计算发出的成本为2800万元(不舍存
某社会工作服务机构聘请一名资深社会工作者担任机构督导者,聘用期满后。双方就督导的效果进行了总结评估。下列评估中,可用于评估社会工作督导效果的有()。
洋务派创建的最早的民用企业是()。
一个老人在高速行驶的火车上,不小心把刚买的新鞋从窗口掉了一只,周围的人倍感惋惜,不料老人立即把第二只鞋也从窗口扔了下去。这举动更让人大吃一惊。老人解释说:“这一只鞋无论多么昂贵,对我而言已经没有用了,如果有谁能捡到一双鞋子,说不定他还能穿呢!”这段文字意在
Somethingkeptscratchingontheoutsideofthetent.Iwouldn’thavethoughtmuchaboutit【C1】______Ihadn’trecentlyseena
ThemostimportantthinginthenewslastweekwastherisingdiscussioninNashvilleabouttheeducationalneedsofchildren.T
最新回复
(
0
)