已知在文件IN13.DAT中存有若干个(个数〈200)4位数字的正整数,函数ReadDat()的功能是读取这若干个
已知在文件IN13.DAT中存有若干个(个数〈200)4位数字的正整数,函数ReadDat()的功能是读取这若干个正整数并存入数组xx中。请编制函数CalValue(),其功能要求: (1)求出该文件中共有多少个正整数totNum; (2)求这些数右移1位后,产生的新数是偶数的数的个数totCnt,以及满足此条件的这些数(右移前的值)的算术平均值totPjz,最后调用函数WriteDat()把所求的结果输出到文件OUT13.DAT中;
注意:部分源程序已给出。
请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
试题程序:
include〈stdio.h>
include〈conio.h>
define MAXNUM 200
int xx [MAXNUM];
int totNum = 0; /* 文件IN13.DAT 中共有多少个正整数 */
int totCnt = 0; /* 符合条件的正整数的个数*/
double totPjz = 0.0; /* 平均值 */
int ReadDat (void);
void Writedat(void);
void CalValue(void)
{
}
main ( )
{
int i;
clrscr ( );
for(i = 0; i〈 MAXNUM; i++)
xx[i] = 0;
if (ReadDat ())
{
print f ( "数据文件 IN13.DAT 不能打开! \007\n" );
return;
}
CalValue ( );
printf("文件IN13.DAT 中共有正整数= %d 个\n", totNum);
printf("符合条件的正整数的个数 = %d 个\n", totCnt);
printf("平均值=%.21f\n", totPjz);
Writedat ( );
}
int ReadDat (void)
{
FILE *fp;
int i = 0;
if((fp = fopen ("IN13.DAT", "r") == NULL)
return 1;
while(! feof(fp) )
{
fscanf(fp, "%d,", &xx[i++]);
}
fclose{fp);
return 0;
}
void WriteDat(void)
{
FILE *fp;
fp = fopen("OUT13.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〈MAXNUM;i++) { if(!xx[i]) continue; /* 如果当前数为0, 则结束本次循环, 取下一个数 */ if (xx[i] >0) totNum++; /* 统计正整数的个数 */ data=xx [i] >>1; /* 将数右移一位 */ if (data%2==0) /* 如果右移1位后,产生的新数是偶数 */ { totCnt++; totPj z+=xx [i]; } /*统计这些数的个数,并将满足条件的原数求和*/ } totPjz/=totcnt; /*求满足条件的这些数(右移前的值)的算术平均值 */ } 解析:本题的解题思路是首先利用一个for循环来依次从数组中取得各数,由于题目要求数组中正整数的个数,因此,零不做任何处理,接着去取下一个数。只要某数大于零,则该数一定是正整数,这时就给变量totNum(正整数的个数)累加1,之后把该正整数右移一位后的结果临时保存在变量data中,再对这个临时变量进行是否偶数的判断。如果该临时变量中保存的值是偶数,则表明原数符合条件,就给变量totCnt(符合判断条件的正整数个数)累加1,并把当前的变量data右移前的原数的值累加到变量totPjz中,当所有符合判断条件的数都被找出后,再对totPjz进行求平均值的计算。
大学VF程序设计题看不懂,1、 求[10,1000]内所有能被被7和9中至少一个数整除的整数之个数 数学 2020-05-16 …
下列程序的功能是:找出所有100以内(含100)满足I,I+4,I+10都是素数的整数重(I+10也 计算机类考试 2020-05-24 …
大学VF程序设计题看不懂,1、求[10,1000]内所有能被被7和9中至少一个数整除的整数之个数. 其他 2020-07-19 …
若1+3+5+…+n>10000,试设计一个程序,寻找满足条件的最小整数n.S=0i=1WHILES 数学 2020-11-01 …
把所有正整数按上小下大,左小右大的原则排成如图所示的数表,其中第i行共有2i-1个正整数,设aij( 其他 2020-11-17 …
把正整数按上小下大、左小右大的原则排成如图所示的数表:第一行有1个正整数,第二行有2个正整数,…,第 其他 2020-11-17 …
正整数按上小下大、左小右大的原则排成如图所示的数表:设aij(i、j∈N*)是位于这个数表中从上往下 其他 2020-11-17 …
把正整数按上小下大、左小右大的原则排成如图所示的数表:设(i、j∈N*)是位于这个数表中从上往下数第 其他 2020-11-17 …
C语言程序:如何确定一个数字i是否为整数?i可能为整数也可能为小数写一下编译程序, 其他 2020-11-23 …
要判断一个数i是否为素数,'只要看i是否能被2到i-1范'围内的数整除,若能被整除,'则不是素数?P 数学 2021-02-13 …