已知数据文件IN24.DAT中存有300个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制函数jsValue(),其功能是:求出千位数上的数加个位数上的数等于百位数上的数加十位数上的数的个数cnt,再把所有满足此条件的4位数依次存入数组

admin2009-02-24  16

问题 已知数据文件IN24.DAT中存有300个4位数,并已调用读函数readDat()把这些数存入数组a中。请编制函数jsValue(),其功能是:求出千位数上的数加个位数上的数等于百位数上的数加十位数上的数的个数cnt,再把所有满足此条件的4位数依次存入数组b中,然后对数组b的4位数按从小到大的顺序进行排序,最后调用写函数writeDat()把数组b中的数输出到OUT24.DAT文件中。
   例如:6712,6+2=7+1,则该数满足条件,存入数组b中,且个数cnt=cnt+1。
         8129,8+9≠1+2,则该数不满足条件,忽略。
   注意:部分源程序已给出。
   程序中已定义数组:a[300],b[300],已定义变量:cnt。
   请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。
   试题程序:
   #include 〈stdio.h>
   int a[300], b[300], cnt=0;

   void 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);
   }

   readDat ( )
   {
       FILE *fp;
       int i;
       fp = fopen("IN24.DAT",  "r");
       for(i=0; i〈300; i++)
           fscanf(fp, "%d,", &a);
       fclose (fp);
   }      
         
   writeDat ()
   {      
       FILE *fp;
       int i;
       fp = fopen("OUT24.DAT", "w");
       fprintf  (fp,  "%d\n",cnt);
       for(i=0; i〈cnt; i++)
           fprintf (fp, "%d, \n", b );
       fclose (fp);
   }

选项

答案void jsValue() { int i, thou, hun, ten, data,j; for(i=0;i〈300;i++) { thou=a[i]/1000; /*求四位数的千位数字*/ hun=a[i]%1000/100; /*求四位数的百位数字*/ ten=a[i]%100/10; /*求四位数的十位数字*/ data=a[i]%10; /*求四位数的个位数字*/ if(thou+data==hun+ten) /*如果千位数加个位数等于百位数加十位数*/ { b[cnt]=a[i]; /*将满足条件的数存入数组b中*/ cnt++; /*统计满足条件的数的个数cnt*/ } } for(i=0;i〈cnt-1;i++) /*用选择法对数组b的4位数按从小到大的顺序进行排序*/ for(j=i+1;j〈cnt;j++) if (b [i]>b [j] ) { data=b[i]; b[i]=b[j]; b [j]=data; } }

解析 根据题意可知,函数jsValue()将实现两个功能:一是找出满足条件的那些数,并存放在数组b中;二是对数组b中的数进行从小到大的排序。首先来实现找出“千位数上的数加上个位数上的数等于百位数上的数加上十位数上的数”的4位数的功能。利用一个for循环来不断从数组a中取出4位数,并对取出的数进行条件判断。由于这里涉及到要对4位数的每一位进行判断,因此,“thou=a/1000;hun=a%1000/100; ten=a%100/10;data=a%10;”这4条语句就可以得到当前被判断的4位数的千位数、百位数、十位数及个位数。之后,执行条件判断语句“if(thou+data==hun+ten)”,并把满足条件的4位数放到数组b中。用变量cnt来统计满足条件的数的个数。将所有满足条件的数取出后利用选择法对其进行排序,即用当前元素依次和它后面的元素进行比较,发现有小于该数的,这两数就进行交换。最终数组b的元素就是有序存放的。
转载请注明原文地址:https://kaotiyun.com/show/DRYZ777K
0

相关试题推荐
最新回复(0)