文件IN.DAT中存有200个四位整型数,函数ReadData()负责将IN.DAT中的数读到数组inBuf[]中。请编写函数findValue(),其功能是:把千位数字和十位数字重新组合成一个新的两位数ab(新两位数的十位数字是原四位数的干位数字,新两位

admin2021-06-16  46

问题 文件IN.DAT中存有200个四位整型数,函数ReadData()负责将IN.DAT中的数读到数组inBuf[]中。请编写函数findValue(),其功能是:把千位数字和十位数字重新组合成一个新的两位数ab(新两位数的十位数字是原四位数的干位数字,新两位数的个位数字是原四位数的十位数字),以及把个位数和百位数组成另一个新的两位数cd(新两位数的十位数字是原四位数的个位数字,新两位数的个位数字是原四位数的百位数字),新组成的两个两位数ab~cd≥10且ab—cd≤20且两个数均为偶数,同时两个新数十位数字均不为零。求出满足条件的数,用count记录下符合条件的数的个数并按照从大到小的顺序存入数组outBuf[]中。函数WriteData()负责将outBuf[]中的数输出到文件OuT.DAT中并且在屏幕上显示出来。
    注意;部分源程序已给出。
    程序中已定义数组:inBuf[200],outBuf[200],已定义变量:count。
    请勿改动主函数main()、读函数ReadData()和写函数WriteData()的内容。
    试题程序:
    #include
    #define NUM 200
    int inBuf[NUM],outBuf[NUM],count=0;
    void ReadData();
    void WriteData();
void findValue()
    }
    void main()
    {
    int i;
    ReadData();
    findValue();I
    WriteData();
    printf(“count=%d\n”,count);
    for(i=0;i    printf(“outBuf[%d]=%d\n”,i,outBuffi]);
    }
    void ReadData()
    {
    FILE*fp;
    int i;
    fp=fopen(“IN.DAT”,“r”);
    for(i=0;i    fseanf(fp,“%d,”,&inBuf);
    fclose(fp);
    }
    void WriteData()
    {
    FILE*fp;   
    int i;
    fp=fopen(“OUT.DAT”,“w”);
    fprintf(fp,“count%d\n”,count);
    for(i=0; i    fprintf(fp,“%d,\n”,outBdf);
    fclose(fp);
}

选项

答案void findValue() { int i.j,k,d[4],temp,minus,ab,cd; for(i=0;i=10&&minus<=20&&1(ab%2+ cd%2)==0&&d[0]!=0&&d[3]!=0 { outBuf[count]=inBuf[i]; count++; } } for(i=0;i
解析 本题主要考查数位分解及排序。
    数位分解就是将n位数上各个数位上的数值单独分离出来。解决此问题的方法是:将n位教对10求余可以将个位上的数值分离出来。将这个n位数除以10以后得到一个n-1位数,则此时n位数原来的十位就变成了n-1位数的个位,再将此n-1位数对10求余便可得到原n位数的十位。依此类推,按照同样的方法便可将n位数各个数位上的数值分离出来。
    程序步骤:①将数值送入temp中。②由temp%10得到个位教;(temp/10)%10得到十位教……如此可得到各位上的数值。③按照题目所给的条件选出数据。④对选出的数据进行排序,排序的思想是(以从小到大为例):将当前数据与其后的各个数据相比较,如果当前的数据比其后的数据大,则将两数据进行交换,从而使得前面的数据小于后面的数据。达到从小到大排序的目的。
转载请注明原文地址:https://jikaoti.com/ti/ktY7FFFM
0

最新回复(0)