欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

已知数据文件IN57.DAT中存有300个4位数,并已调用读函数readDat()把这些数存入数组a中,请编制一函

时间:2018-05-06

已知数据文件IN57.DAT中存有300个4位数,并已调用读函数readDat()把这些数存入数组a中,请编制一函幼sValue(),其功能是:求出个位数上的数减千位数上数减百位数上的数减十位数上的数大于零的个数cnt,再把所有满足此条件的4位数依次存入数组b中,然后对数组b的4位数按从大到小的顺序进行排序,最后调用函数writeDat()把数组b中的数输出到OUT57.DAT文件中。


例如:1239,9-1-2-3>0,则该数满足条件,存入数组b中,且个数cnt=cnt+1。


8129,9-8-1-2<0,则该数不满足条件,忽略。


注意:部分源程序已给出。


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


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


试题程序:


include


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


jsValue()


{


}


main()


{


int i;


readDat();


jsValue();


writeDat();


printf("cnt=%d\n",cnt);


for(i=0;i<cnt;i++)


printf("b[%d];%d\n",i,b[i]);


{


readDat()


{


FILE *fp;


int i;


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


for(i=0;i<300;i++)


fscanf(fp,"%d,",&a[i]);


fclose(fp);


}


writeDat()


{


FILE *fp;


int i;


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


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


for(i=0;i<cnt;i++)


fprintf(fp, "%d\n",b[i]);


fclOse(fp);


}



答案说明:本题目答案来自网络整理或转载,最终答案请以官网为准。


答 案:jsValue() { int ithouhuntendataj; for(i=0;i300;i++) { thou=a[i]/1000; /*求四位数的千位数字*/ hun=a[i]%1000/100; /*求四位数的百位数字*/ ten=a[i]%100/10; /*求四位数的十位数字*/ data=a[i]%10/ /*求四位数的个位数字*/ if(data-hun-ten-thou>O) /*如果个位数减千位数减百位数减十位数大于零*/ { b[cnt]=a[i]); /*则将满足条件的数存入数组b中*/ cnt++ /*统计满足条件的数的个数*/ } } for(i=0;icnt-1;i++) /*对数组b的4位数按从大到小的顺序进行排序*/ for(j=i+l;jcnt;i++) if(b[i]b[i]) { data=b[i]; b[i]=b[i]; b[j]=data; } }
jsValue() { int i,thou,hun,ten,data,j; for(i=0;i300;i++) { thou=a[i]/1000; /*求四位数的千位数字*/ hun=a[i]%1000/100; /*求四位数的百位数字*/ ten=a[i]%100/10; /*求四位数的十位数字*/ data=a[i]%10/ /*求四位数的个位数字*/ if(data-hun-ten-thou>O) /*如果个位数减千位数减百位数减十位数大于零*/ { b[cnt]=a[i]); /*则将满足条件的数存入数组b中*/ cnt++ /*统计满足条件的数的个数*/ } } for(i=0;icnt-1;i++) /*对数组b的4位数按从大到小的顺序进行排序*/ for(j=i+l;jcnt;i++) if(b[i]b[i]) { data=b[i]; b[i]=b[i]; b[j]=data; } } 解析:本题考查的知识点如下:
(1)运算:符“%”及“/”的使用。
(2)循环结构及选择结构的使用。
在本题中,首先要将一个4位数的千位、百位、十位、个位拆成独立的数字。这里借助特殊运算符号“%”(取余)和“/”(整除)。将一个4位数整除1000则可得到其千位上的数字,除以1000取余再整除100则可得百位上的数字,除以100取余再整除10则可得十位上的数字,除以10取余则得个位上的数字。然后按照题意要求将各位依次相减进行判断。将符合条件的数存入数组b中,最后的排序采用“选择排序法”。
相关推荐

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。