已知数据文件IN29.DAT中存有200个4位数 并已调用读函数readDat( )把这些数存入数组
已知数据文件IN29.DAT中存有200个4位数,并已调用读函数readDat( )把这些数存入数组a中,请编制一函数jsVal( ),其功能是:把个位数字和千位数字重新组合成一个新的十位数ab(新十位数的十位数字是原4位数的个位数字,新十位数的个位数字是原4位数的千位数字),以及把百位数字和十位数字组成另一个新的十位数cd(新十位数的十位数字是原4位数的百位数字,新十位数的个位数字是原4位数的十位数字),如果新组成的两个数均为偶数且两个十位数中至少有一个数能被9整除,同时两个新十位数字均不为零,则将满足此条件的4位数按从大到小的顺序存入数组b中,并计算满足上述条件的4位数的个数cnt,最后调用写函数writeDat( )把结果cnt及数组b中符合条件的4位数输出到OUT29.DAT文件中。
注意:部分源程序已给出。
程序中已定义数组:a[200],b[200],已定义变量:cnt。
请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。
参考解答
答案:
#include
#define MAX 200
int a[MAX,b[MAX,cnt=0;
void writeDat();
void jsVal( )
{
int i,j; /*定义循环控制变量*/
int a1,a2,a3,a4; /*定义变量保存4位数的每位数字*/
int temp; /*定义数据交换时的暂存变量*/
int ab,cd; /*存储重新组合成的十位数*/
for(i=0;i<200;i++) /*逐个取每一个4位数*/
{
a4=a[i/1000; /*求4位数的千位数字*/
a3=a[i%1000/100; /*求4位数的百位数字*/
a2=a[i%100/10; /*求4位数的十位数字*/
a1=a[i%10; /*求4位数的个位数字*/
ab=10*a1+a4; /*把个位数和千位数重新组合成一个新的十位数ab*/
cd=10*a3+a2; /*把百位数和十位数组成另一个新的十位数cd*/
if((ab%9==0||cd%9==0)&&(ab%2!=1)&&(cd%2!=1)&&a1!=0&&a3!=0)
/*如果新组成的两个数均为偶数且两个十位数中至少有一个数能被9整除,同时两个新十位的十位上的数字均不为零*/
{
b[cnt=a[i; /*将满足条件的4位数存入数组b中*/
cnt++; /*统计满足条件的数的个数*/
for(i=0;i
for(j=i+1;j
if(b[i
{
temp=b[i;
b[i=b[j;
b[j=temp;
void readDat( )
{
int i;
FILE *fp;
fp=fopen('IN29.DAT','r');
for(i=0;i
fscanf(fp,'%d',&a[i);
fclose(fp);
void main()
{
int i;
readDat();
jsVal();
printf('满足条件的数=%d\n',cnt);
for(i=0;i
printf('%d\n',b[i);
printf('\n');
writeDat();
void writeDat()
{
FILE *fp;
int i;
fp=fopen('OUT29.DAT','w');
fprintf(fp,'%d\n',cnt);
for(i=0;i
fprintf(fp, '%d\n',b[i);
fclose(fp);
相似问题
简述从层次化的角度来看 嵌入式系统可以分为哪些层。
简述从层次化的角度来看,嵌入式系统可以分为哪些层。
信息系统的容灾方案通常要考虑的要点有( )。A.灾难的类型B.恢复时间C.恢复程度D.实用技术E.成
信息系统的容灾方案通常要考虑的要点有( )。A 灾难的类型B 恢复时间C 恢复程度D 实用技术E 成本
简述嵌入式程序优化遵循的原则。
简述嵌入式程序优化遵循的原则。
某网络采用子网划分技术 所需子网数为12 求该网络的实际子网数目为( )。A)12B)14C)16D
某网络采用子网划分技术,所需子网数为12,求该网络的实际子网数目为( )。A)12B)14C)16D)254
从下列关于软件测试的叙述中 选出5条正确的叙述( )。(1)用黑盒法测试时 测试用例是根据程序内部逻
从下列关于软件测试的叙述中,选出5条正确的叙述( )。(1)用黑盒法测试时,测试用例是根据程序内部逻辑设计的。(2)尽量用公共过程或子程序去代替重复的代