2016年計(jì)算機(jī)三級(jí)數(shù)據(jù)庫(kù)技術(shù)考前試題及答案(6)

字號(hào):


    1.已知數(shù)據(jù)文件IN37.DAT中存有200個(gè)4位數(shù),并已調(diào)用讀函數(shù)readDat( )把這些數(shù)存入數(shù)組a中,請(qǐng)編制一函數(shù)jsVal(),其功能是:依次從數(shù)組a中取出一個(gè)4位數(shù),如果該4位數(shù)連續(xù)大于該4位數(shù)以前的5個(gè)數(shù)且該數(shù)是偶數(shù)(該4位數(shù)以前不滿5個(gè)數(shù),則不統(tǒng)計(jì)),則統(tǒng)計(jì)出滿足此條件的數(shù)個(gè)數(shù)cnt并把這些4位數(shù)按從大到小的順序存入數(shù)組b中,最后調(diào)用寫(xiě)函數(shù)writeDat()把結(jié)果cnt及數(shù)組b中符合條件的4位數(shù)輸出到文件OUT37.DAT中。
    注意:部分源程序已給出。
    程序中已定義數(shù)組:a[200],b[200],已定義變量:cnt。
    請(qǐng)勿改動(dòng)主函數(shù)main( )、讀函數(shù)readDat()和寫(xiě)函數(shù)writeDat( )的內(nèi)容。
    #include
    #define MAX 200
    int a[MAX],b[MAX],cnt=0;
    void writeDat();
    void jsVal()
    {
    int i,j; /*定義循環(huán)控制變量*/
    int temp; /*定義數(shù)據(jù)交換是的暫存變量*/
    for(i=5;i
    if(a[i]%2==0) /*如果當(dāng)前數(shù)是偶數(shù)*/
    for(j=i-5;j<=i-1;j++) /*取該數(shù)前面的5個(gè)數(shù)進(jìn)行比較*/
    {
    if(a[i]
    break; /*如果當(dāng)前數(shù)不滿足比前面5個(gè)數(shù)都大的條件,則跳出循環(huán)*/
    else if(j==i-1) /*如果當(dāng)前數(shù)比前面的5個(gè)數(shù)都大*/
    {
    b[cnt]=a[i]; /*將滿足條件的數(shù)存入數(shù)組b中*/
    cnt++; /*并統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/
    }
    }
    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("in37.dat","r");
    for(i=0;i
    fscanf(fp,"%d",&a[i]);
    fclose(fp);
    }
    void main()
    {
    int i;
    readDat();
    jsVal();
    printf("滿足條件的數(shù)=%d\n",cnt);
    for(i=0;i
    printf("%d ",b[i]);
    printf("\n");
    writeDat();
    }
    void writeDat()
    {
    FILE *fp;
    int i;
    fp=fopen("out37.dat","w");
    fprintf(fp,"%d\n",cnt);
    for(i=0;i
    fprintf(fp,"%d\n",b[i]);
    fclose(fp);
    }
    2.已知數(shù)據(jù)文件IN38.DAT中存有200個(gè)4位數(shù),并已調(diào)用讀函數(shù)readDat()把這些數(shù)存入數(shù)組a中。請(qǐng)編制函數(shù)jsVal(),其功能是:依次從數(shù)組a中取出一個(gè)4位數(shù),如果4位數(shù)連續(xù)大于該4位數(shù)以前的5個(gè)數(shù)且該數(shù)是奇數(shù)(該4位數(shù)以前不滿5個(gè)數(shù),則不統(tǒng)計(jì)),該數(shù)必須能被7整除,則統(tǒng)計(jì)出滿足此條件的數(shù)的個(gè)數(shù)cnt,并把這些4位數(shù)按從大到小的順序存入數(shù)組b中,最后調(diào)用寫(xiě)函數(shù)writeDat()把結(jié)果cnt及數(shù)組b中符合條件的4位數(shù)輸出到OUT38.DAT文件中。
    注意:部分源程序已給出。
    程序中已定義數(shù)組:a[200],b[200],已定義變量:cnt。
    請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)readDat()和寫(xiě)函數(shù)writeDat()的內(nèi)容。
    #include
    #define MAX 200
    int a[MAX], b[MAX], cnt = 0;
    void writeDat();
    void jsVal()
    {
    int i,j; /*定義循環(huán)控制變量*/
    int temp; /*定義數(shù)據(jù)交換是的暫存變量*/
    for(i=5;i
    if(a[i]%2!=0 && a[i]%7==0) /*如果當(dāng)前數(shù)是奇數(shù)且可以被7整除*/
    for(j=i-5;j<=i-1;j++) /*取該數(shù)前面的5個(gè)數(shù)進(jìn)行比較*/
    {
    if(a[i]
    break; /*如果當(dāng)前數(shù)不滿足比前面5個(gè)數(shù)都大的條件,則跳出循環(huán)*/
    else if(j==i-1) /*如果當(dāng)前數(shù)比前面的5個(gè)數(shù)都大*/
    {
    b[cnt]=a[i]; /*將滿足條件的數(shù)存入數(shù)組b中*/
    cnt++; /*并統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/
    }
    }
    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("IN38.DAT", "r");
    for(i=0; i
    fscanf(fp, "%d", &a[i]);
    fclose(fp);
    }
    void main()
    {
    int i;
    readDat();
    jsVal();
    printf("滿足條件的數(shù)=%d\n", cnt);
    for(i=0; i
    printf("%d ", b[i]);
    printf("\n");
    writeDat();
    }
    void writeDat()
    {
    FILE *fp;
    int i;
    fp = fopen("OUT38.DAT", "w");
    fprintf(fp, "%d\n", cnt);
    for(i=0; i
    fprintf(fp, "%d\n", b[i] );
    fclose(fp);
    }