早教吧 育儿知识 作业答案 考试题库 百科 知识分享
早教吧考试题库频道 --> 计算机类考试 -->计算机三级 -->

已知IN7.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中,请编制一函数 jsVal(

题目

已知IN7.DAT中存有200个4位数,并已调用读函数readDat()把这些数存入数组a中,请编制一函数 jsVal(),其功能是:依次从数组a中取出一个数,如果该4位数连续大于该4位数以后的5个数且该数是奇数,则统计出满足此条件的数的个数ont,并把这些4位数按从小到大的顺序存入数组b中,最后调用写函数 writeDat()把结果cnt及数组b中符合条件的4位数输出到OUT7.DAT文件中。

程序中已定义数组:a[200],b[200],已定义变量:cnt。

请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。

试题程序:

include <stdio.h>

define MAX 200

int a[MAX], b[MAX], cnt = 0;

void writeDat();

void jsVal()

{

}

void readDat ()

{

int i;

FILE *fp;

fp = fopen("IN7.DAT", "r");

for(i = 0; i < MAX; i++) fscanf(fp, "%d", &a[i]);

close (fp);

}

main ( )

{

int i;

readDat ();

jsVal ();

printf("满足条件的数=%d\n", cnt);

for(i=0; i < cnt; i++) printf("%d ", b[i]);

printf ("\n");

writeDat ();

}

void writeDat()

{

FILE *fp;

int i;

fp = fopen("OUT7.DAT", "w");

fprintf(fp, "%d\n", cnt);

for(i = 0; i < cnt; i++) fprintf(fp, "%d\n", b[i]);

fclose (fp);

}

参考答案
正确答案:void jsVal() { int iiflag=O; int k; for(i=0;iMAX-5;i++) { for(j=i+1;j=i+5;j++) /*如果当前数比后面的5个数都大则给标志变量 flag赋值1*/ { if (a[i]>a[i]) flag=1; else{flag=O;break;} /*否则给标志变量flag赋值0并退出循环*/ if(a[i]%2==0) /*如果该数是偶数也给标志变量flag赋值0*/ flag=0; } if (flag==1) /*将满足条件的数存入数组b中并统计满足条件的数的个数*/ {b[cnt]=a[i];cnt++;) } for(i=O;icnt-;i++) /*利用选择法对b数组中的元素进行从小到大的排序*/ for(i=i+1;;jcnt;i++) if (b[i]>b[i]) {k=b[i];b[i]=b[j];b[j]=k;) }
void jsVal() { int i,i,flag=O; int k; for(i=0;iMAX-5;i++) { for(j=i+1;j=i+5;j++) /*如果当前数比后面的5个数都大,则给标志变量 flag赋值1*/ { if (a[i]>a[i]) flag=1; else{flag=O;break;} /*否则给标志变量flag赋值0并退出循环*/ if(a[i]%2==0) /*如果该数是偶数,也给标志变量flag赋值0*/ flag=0; } if (flag==1) /*将满足条件的数存入数组b中,并统计满足条件的数的个数*/ {b[cnt]=a[i];cnt++;) } for(i=O;icnt-;i++) /*利用选择法对b数组中的元素进行从小到大的排序*/ for(i=i+1;;jcnt;i++) if (b[i]>b[i]) {k=b[i];b[i]=b[j];b[j]=k;) } 解析:根据题意可知,要编制函数的功能有两部分:一是找出满足条件的4位数,二是对找出的数进行从小到大排序。首先利用一个for循环来依次从数组中取得4位数,接着用当前得到的4位数与该数后面的5个数依次进行比较,如果该数比后面的5个数都大,则给标志变量flag赋值1,接着对flag进行判断,如果不为1,则该数肯定不符合条件,直接去取下一个数。若flag值为1,再来判断该数是否是奇数,如果该数又是奇数,则把该数加入到数组b中。这样就可以依次取出合条件的数。然后利用选择法对b数组中的元素进行从小到大的排序。