國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷7(共9題)_第1頁(yè)
國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷7(共9題)_第2頁(yè)
國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷7(共9題)_第3頁(yè)
國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷7(共9題)_第4頁(yè)
國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷7(共9題)_第5頁(yè)
已閱讀5頁(yè),還剩4頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷7(共9套)(共9題)國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷第1套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、函數(shù)RData()實(shí)現(xiàn)從文件IN.dat中讀取一篇英文文章,存入字符串?dāng)?shù)組str中,請(qǐng)編寫函數(shù)encryptChar(),其功能是:按給定的替代關(guān)系對(duì)數(shù)組str中的所有字符進(jìn)行替代后,仍存入數(shù)組str的對(duì)應(yīng)位置上。最后調(diào)用函數(shù)WData(),把結(jié)果str輸出到OUT.dat文件中。替代關(guān)系:f(p)=p*11mod256(p是數(shù)組中某一個(gè)字符的ASCII值,f(p)是計(jì)算后新字符的ASCII值),如果原字符是大寫字母或計(jì)算后f(p)值小于等于32,則該字符不變,否則將f(p)所對(duì)應(yīng)的字符進(jìn)行替代。原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個(gè)字符。注意:部分程序已經(jīng)給出。請(qǐng)勿改動(dòng)主函數(shù)main()、讀數(shù)據(jù)函數(shù)RData()和輸出數(shù)據(jù)函數(shù)WData()的內(nèi)容。#include<stdio.h>#include<string.h>#include<conio.h>#include<ctype.h>unsignedcharstr[50][80];intmaxline=0;/*文章的總行數(shù)*/intRData(void);voidWData(void);voidencryptChar(){}voidmain(){if(RData()){printf("數(shù)據(jù)文件IN.dst不能打開(kāi)!\n\007");return;}encryptChar();WData();}intRData(void){FILE*fp;inti=0;unsignedchar*p;if((fp=fopen("IN.dat","r"))==NULL)return1;while(fgets(str[i],80,fp)!=NULL){p=strchr(str[i],’\n’);if(p)*p=0;i++;}maxline=i;fclose(fp);return0;}voidWData(void){FILE*fp;inti;fp=fopen("OUT.dat","w");for(i=0;i<maxline;i++){printf("%s\n",str[i]);fprintf(fp,"%s\n",str[i]);}fclose(fp);}標(biāo)準(zhǔn)答案:voidencryptChar(){inti;char*pf;for(i=0;i<maxline;i++){pf=str[i];while(*pf!=0){if((*pf>=’A’&&*pf<=’Z’)||*pf*11%256<=32){pf++;continue;}*pf=*pf*11%256;pf++;}}}[解題思路]在for循環(huán)語(yǔ)句中對(duì)字符串?dāng)?shù)組str中的每個(gè)字符用邏輯表達(dá)式(*pf>=’A’&&*pf<=’Z’)||*pf*11%256<=32進(jìn)行邏輯判斷,如果其值為1,則該字符不變,否則按照給定的替代關(guān)系f(p)=p*11mod256求出其要替代的字符的ASCII值,然后對(duì)該字符進(jìn)行替代。知識(shí)點(diǎn)解析:暫無(wú)解析國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷第2套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、已知在文件IN1.DAT中存有100個(gè)產(chǎn)品銷售記錄,每個(gè)產(chǎn)品銷售記錄由產(chǎn)品代碼dm(字符型4位)、產(chǎn)品名稱mc(字符型10位)、單價(jià)dj(整型)、數(shù)量sl(整型)、金額je(長(zhǎng)整型)五部分組成。其中:金額=單價(jià)×數(shù)量。函數(shù)ReadDat()的功能是讀取這100個(gè)銷售記錄并存入結(jié)構(gòu)數(shù)組sell中。請(qǐng)編制函數(shù)SortDat(),其功能要求:按產(chǎn)品名稱從小到大進(jìn)行排列,若產(chǎn)品名稱相同,則按金額從小到大進(jìn)行排列,最終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組sell中,最后調(diào)用函數(shù)WriteDat()把結(jié)果輸出到文件OUT1.DAT中。注意:部分源程序已給出。請(qǐng)勿改動(dòng)主函數(shù)main()、讀數(shù)據(jù)函數(shù)ReadDat()和輸出數(shù)據(jù)函數(shù)WriteDat()的內(nèi)容?!驹囶}程序】#include<stdio.h>#include<memory.h>#include<string.h>#include<conio.h>#include<stdlib.h>#defineMAX100typedefstruct{chardm[5];/*產(chǎn)品代碼*/charmc[11];/*產(chǎn)品名稱*/intdj;/*單價(jià)*/intsl;/*數(shù)量*/longje;/*金額*/}PRO;PROsell[MAX];voidReadDat();voidWriteDat();voidSortDat(){}main(){memset(sell,0,sizeof(sell));ReadDat();SortDat();WriteDat();}voidReadDat({FILE*fp;charstr[80],ch[11];inti;fp=fopen("IN1.DAT","r");for(i=,0;i<100;i++){fgets(str,80,fp);memcpy(sell[i].dm,str,4);memcpy(sell[i].mc,str+4,10);memcpy(ch,str+14,4);ch[4]=0;sell[i].dj=atoi(ch);memcpy(ch,str+18,5);ch[5]=0;sell[i].sl=atoi(ch);sell[i].je=(long)sell[i].dj*sell[i].sl;}fclose(fp);}voidWriteDat(){FILE*fp;inti;fp=fopen("OUT1.DAT","w");for(i=0;i<100;i++)fprintf(fp,"%s%s%4d%5d%101d\n",sell[i].dm,sell[i].mc,sell[i].dj,sell[i].sl,sell[i].je);fclose(fp);}標(biāo)準(zhǔn)答案:voidSortDat(){inti,j;PROxy;for(i=0;i<99;i++)for(j=i+1;j<100;j++){if(sell[i].mc>sell[j].mc)/*按產(chǎn)品名稱從小到大進(jìn)行排列*/{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}elseif((sell[i].mc==sell[j].mc)&&(sell[i].je>sell[j].je))/*若產(chǎn)品名稱相同則按金額從小到大進(jìn)行排列*/{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}}}或者直接使用庫(kù)函數(shù)中的字符串比較函數(shù)strcmp(),即voidSortDat(){inti,j;PROxy;for(i=0;i<99;i++)for(j=i+1;j<100;j++){if(strcmp(sell[i].mc,sell[j].mc)>0/*按產(chǎn)品名稱從小到大進(jìn)行排列*/{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}elseif(strcmp(sell[i].mc,sell[j].mc)==0)/*若產(chǎn)品名稱相同*/if(sell[i].je>sell[j].je)/*則按金額從小到大進(jìn)行排列*/{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}}}知識(shí)點(diǎn)解析:根據(jù)題目要求,先按產(chǎn)品名稱從小到大的順序進(jìn)行排列,若產(chǎn)品名稱相同,則按金額從小到大進(jìn)行排列。由產(chǎn)產(chǎn)品名稱是字符型,而定兩字符的大小依據(jù)是其ASCII碼值。在此就用選擇排序法來(lái)實(shí)現(xiàn),用第一個(gè)元素的產(chǎn)品名稱和它后面的元素的產(chǎn)品名稱進(jìn)行比較,若發(fā)現(xiàn)當(dāng)前元素的產(chǎn)品名稱比后面的某個(gè)元素的產(chǎn)品名稱對(duì)應(yīng)的ASCII碼值更大,則交換這兩個(gè)元素的位置。依次類推,最終在第一個(gè)元素中存放的是產(chǎn)品名稱最小的元素,這樣就實(shí)現(xiàn)了該函數(shù)排序的功能。編寫此函數(shù)時(shí),對(duì)于初學(xué)者來(lái)說(shuō)建議用以下函數(shù)來(lái)表達(dá):if(sell[i].mc>sell[j].mc){t=sell[i];sell[i]=sell[j];sell[j]=t;}elseif((sell[i].mc==sell[j].mc)&&(sell[i].je>sell[j].je)){t=sell[i];sell[i]=sell[j];sell[j]=t;}而對(duì)于有一定基礎(chǔ)的編程者來(lái)說(shuō)可運(yùn)用下面語(yǔ)句來(lái)實(shí)現(xiàn):if((sell[i].mc>sell[j].mc)‖(sell[i].mc==sell[j].mc)&&(sell[i].je>sell[j].je))該語(yǔ)句的含義是先sell[i].mc>sell[j].mc進(jìn)行比較,若產(chǎn)品名稱滿足此條件,就對(duì)這兩個(gè)數(shù)據(jù)位置調(diào)換;否則,就判斷產(chǎn)品名稱是否相等,若相等就對(duì)金額進(jìn)行大小比較?最終實(shí)現(xiàn)按從小到大的順序排列。國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷第3套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、已知數(shù)據(jù)文件IN76.DAT中存有200個(gè)4位數(shù),并己調(diào)用讀函數(shù)readDat()把這些數(shù)存入數(shù)組a中,請(qǐng)編制一函數(shù)jsval(),其功能是:把個(gè)位數(shù)字和千位數(shù)字重新組合成一個(gè)新的十位數(shù)ab(新十位數(shù)的十位數(shù)字是原4位數(shù)的個(gè)位數(shù)字,新十位數(shù)的個(gè)位數(shù)字是原4位數(shù)的千位數(shù)字),以及把百位數(shù)和十位數(shù)組成另一個(gè)新的十位數(shù)cd(新十位數(shù)的十位數(shù)字是原4位數(shù)的百位數(shù)字,新十位數(shù)的個(gè)位數(shù)字是原4位數(shù)的十位數(shù)字),如果新組成的兩個(gè)十位數(shù)必須是一個(gè)奇數(shù),另一個(gè)為偶數(shù)且兩個(gè)十位數(shù)中至少有一個(gè)數(shù)能被17整除,同時(shí)兩個(gè)新十位數(shù)字均不為0,則將滿足此條件的4位數(shù)按從大到小的順序存入數(shù)組b中,并要計(jì)算滿足上述條件的4位數(shù)的個(gè)數(shù)cnt,最后調(diào)用寫函數(shù)writeDat()把結(jié)果cnt及數(shù)組b中符合條件的4位數(shù)輸出到OUT76.DAT文件中。注意:部分源程序已給出。程序中已定義數(shù)組:a[200],b[200],已定義變量:cnt。請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)readDat()和寫函數(shù)wiltedat()的內(nèi)容。試題程序:#include<stdio.h>#defineMAX200inta[MAX],b[MAX],cnt=0;voidjsVal(){}voidreadDat(){inti;FILE*fp;fp=fopen("IN76.DAT","r");for(i=0;i<MAX;i++)fscanf(fp,"%d",&a[i]);fclose(fp);}main(){inti;readDat();jsVal();printf("滿足條件的數(shù)=%d\n"cnt);for(i=0;i<cnt;i++)printf("%d",b[i]);printf("\n");writeDat();}writeDat(){FILE*fp;inti;fp=fopen("OUT76.DAT","w");fprintf(fp,"%d\n",cnt);for(i=0;i<cnt;i++)fprintf(fp,"%d\n",b[i]);fclose(fp);}標(biāo)準(zhǔn)答案:voidjsVal(){inti,thou,hun,ten,dara,j;intab,cd;for(i=0;i<200;i++){thou=a[i]/1000;/*求四位數(shù)的千位數(shù)字*/hun=a[i]%1000/100;/*求四位數(shù)的百位數(shù)字*/ten=a[i]%100/10;/*求四位數(shù)的十位數(shù)字*/data=a[i]%10;/*求四位數(shù)的個(gè)位數(shù)字*/ab=data*10+thou;/*把個(gè)位數(shù)和千位數(shù)組合成一個(gè)新的十位數(shù)ab*/cd=hun*10+ten;/*把百位數(shù)和十位數(shù)組成另一個(gè)新的十位數(shù)cd*/if((ab%17==0||c(diǎn)d%17==0)&&((ab%2!=1&&cd%2==1)||(ab%2==1&&cd%2!=1))&&ab!=0&&cd!=0){/*如果新組成的兩個(gè)十位數(shù)必須是一個(gè)奇數(shù),另一個(gè)為偶數(shù)且兩個(gè)十位數(shù)中至少有一個(gè)數(shù)能被17整除,同時(shí)兩個(gè)新十位數(shù)字均不為0*/b[cnt]=a[i];/*則將滿足條件的數(shù)存入數(shù)組b中*/cnt++;/*統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/}}for(i=0;i<cnt-1;i++)/*將數(shù)組b中的數(shù)按從到小的順序排列*/for(j=i+1;j<cnt;j++)if(b[i]<b[j]){data=b[i];b[i]=b[j];b[j]=data;}}知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:(1)將一個(gè)4位整數(shù)各位上的數(shù)轉(zhuǎn)變成單獨(dú)的個(gè)位數(shù)。(2)判斷結(jié)構(gòu)中多個(gè)條件的布爾運(yùn)算。(3)循環(huán)的使用。(4)數(shù)據(jù)的排序。在本題中,首先要將一個(gè)4位數(shù)的千位、百位、十位、個(gè)位拆成獨(dú)立的數(shù)字。這里借助特殊運(yùn)算符號(hào)“%”(取余)和“/”(控除)。將一個(gè)4位數(shù)整除1000則可得到其千位上的數(shù)字,除以1000取余再整除100則可得百位上的數(shù)字,除以100取余再整除10則可得十位上的數(shù)字,除以10取余則得個(gè)位上的數(shù)字。若一個(gè)數(shù)除以2取余為0,則這個(gè)數(shù)是偶數(shù),否則為奇數(shù)。兩個(gè)數(shù)必須一個(gè)為奇數(shù),另一個(gè)為偶數(shù),這就有兩種情況:ad為奇數(shù),cd為偶數(shù);或者ab為偶數(shù),cd為奇數(shù)。兩者滿足一種即可,所以這兩種情況間用“或”運(yùn)算。兩個(gè)數(shù)中至少有1個(gè)能被17整除,曲能被17整除與cd能被17整除兩個(gè)條件滿足一個(gè)即可,所以這兩個(gè)條件之間用“或”運(yùn)算。但這個(gè)條件與其他條件必須同時(shí)滿足,所以此條件與其他條件之間用“與”運(yùn)算。先將滿足條件的數(shù)存入數(shù)組b中,再對(duì)數(shù)組中的數(shù)據(jù)進(jìn)行排序。最后的排序采用“選擇排序法”。國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷第4套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、下列程序的功能是:選出5000以下符合條件的自然數(shù)。條件是:千位數(shù)字與百位數(shù)字之和等于十位數(shù)字與個(gè)位數(shù)字之和,且千位數(shù)字與百位數(shù)字之和等于個(gè)位數(shù)字與千位數(shù)字之差的10倍。計(jì)算并輸出這些4位自然數(shù)的個(gè)數(shù)cnt及這些數(shù)的和sum。請(qǐng)編寫函數(shù)countValue()實(shí)現(xiàn)程序的要求,最后調(diào)用函數(shù)writeDAT()把結(jié)果cnt和sum輸出到文件OUT67.DAT中。注意:部分源程序已給出。請(qǐng)勿改動(dòng)主函數(shù)main()和寫函數(shù)writeDAT()的內(nèi)容。試題程序:#include<stdio.h>intcnt,sum;voidcountValue(){}voidmain(){cnt=sum=0;countValue();printf("滿足條件的自然數(shù)的個(gè)數(shù)=%d\n",cnt);printf("滿足條件的自然數(shù)的值的和=%d\n",sum);writeDAT();}writeDAT(){FILE*fp;fp=fopen("OUT67.DAT","w");fprintf(fp,"%d\n%d\n",cnt,sum);fclose(fp);}標(biāo)準(zhǔn)答案:voidcountValue(){inti,thou,hun,ten,data;for(i=5000;i>=1000;i--){thou=i/1000;/*求四位數(shù)的千位數(shù)字*/hun=i%1000/100;/*求四位數(shù)的百位數(shù)字*/ten=i%100/10;/*求四位數(shù)的十位數(shù)字*/data=i%10;/*求四位數(shù)的個(gè)位數(shù)字*/if(thou+hun==ten+data&&thou+hun==(data-thou)*10){/*千位數(shù)與百位數(shù)之和等于十位數(shù)與個(gè)位數(shù)之和,且千位數(shù)與百位數(shù)之和等于個(gè)位數(shù)與千位數(shù)之差的10倍*/cnt++;/*則統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/sum+=i;/*將滿足條件的數(shù)求和*/}}}知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:(1)“%”與“/”的使用。(2)判斷結(jié)構(gòu)中多個(gè)條件的布爾運(yùn)算。(3)循環(huán)結(jié)構(gòu)的使用。本題要求選出5000以下符合條件的4位數(shù),所以選擇范圍是1000到5000。這里要借助運(yùn)算符“%”與“/”將4位數(shù)各位上的數(shù)拆成獨(dú)立的數(shù)字:將1個(gè)4位數(shù)整除1000則可得到其千位上的數(shù)字,除以1000取余再整除100則可得百位上的數(shù)字,除以100取余再整除10則可得十位上的數(shù)字,除以10取余則得個(gè)位上的數(shù)字。題中給出的兩個(gè)條件都要滿足,所以兩條件之間用“與”運(yùn)算。使用循環(huán)結(jié)構(gòu)對(duì)1000到5000之間的數(shù)依次進(jìn)行上述的處理。國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷第5套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、已知數(shù)據(jù)文件IN89.DAT中存有200個(gè)4位數(shù),并已調(diào)用讀函數(shù)readDat()把這些數(shù)存入數(shù)組a中。請(qǐng)編制一函數(shù)jsVal(),其功能是:如果一個(gè)4位數(shù)的千位數(shù)字上的值加個(gè)位數(shù)字上的值恰好等于百位數(shù)字上的值加上十位數(shù)字上的值,并且此4位數(shù)是奇數(shù),則統(tǒng)計(jì)出滿足此條件的數(shù)的個(gè)數(shù)cnt并把這些4位數(shù)按從小到大的順序存入數(shù)組b中,最后調(diào)用寫函數(shù)writeDat()把結(jié)果cnt以及數(shù)組b中符合條件的4位數(shù)輸出到OUT89.DAT文件中。注意:部分源程序已給出。程序中己定義數(shù)組:a[200],b[200],已定義變量:cnt。請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)readDat()和寫函數(shù)writeDat()的內(nèi)容。試題程序:#include<stdio.h>#defineMAX200inta[MAX],b[MAX],cnt=0;voidjsVal(){}voidreadDat(){inti;FILE*fp;fp=fopen("IN89.DAT","r");for(i=0;i<MAX;i++)fscanf(fp,"%d",&a[i]);fclose~fp);}main(){inti;readDat();jsVal();printf("滿足條件的數(shù)=%d\n",cnt);for(i=0;i<cnt;i++)printf("%d",b[i]);printf("\n");writeDat();}writeDat(){FILE*fp;inti;fp=fopen("OUT89.DAT","w");fprintf(fp,"%d\n",cnt);for(i=0;i<cnt;i++)fprintf(fp,"%d\n",b[i]);fclose(fp);~’}標(biāo)準(zhǔn)答案:voidjsVal(){inti,thou,hun,ten,data,j;for(i=0;i<200;i++){thou=[i]%1000/100;/*求四位數(shù)的首位數(shù)字*/ten=[i]%100/10;/*求四位數(shù)的十位數(shù)字*/data=a[i]%10;/*求四位數(shù)的個(gè)位數(shù)字*/if((thou+data==hun+ten)&&a[i]%2==1)/*如果千位數(shù)加個(gè)位數(shù)等于百位數(shù)加十位數(shù),并且此數(shù)是奇數(shù)*/{b[cnt]=a[i];/*則將滿足條件的數(shù)存入數(shù)組b中*/cnt++;/*統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/}}for(i=0;i<cnt-1;i++)/*將數(shù)組b中的數(shù)按從小到大的順序排列*/for(j=i+1;i<cnt;j++)if(b[i]>b[i]){data=b[i];b[i]=b[j]);b[j]=data;}}知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:(1)運(yùn)算符“%”及“/”的使用。(2)選擇結(jié)構(gòu)中多個(gè)條件的布爾運(yùn)算。(3)數(shù)據(jù)的排序。在本題中,首先要將一個(gè)4位數(shù)的千位、百位、十位、個(gè)位拆成獨(dú)立的數(shù)字。這里借助特殊運(yùn)算符號(hào)“%”(取余)和“/”(整除),拆分方法略。一個(gè)數(shù)除以2取余所得的數(shù)為1,則這個(gè)數(shù)是奇數(shù)。題中給出的兩個(gè)條件必須同時(shí)滿足,所以兩條件之間用“與”運(yùn)算。將符合條件的數(shù)先存入數(shù)組b中,再對(duì)b中的數(shù)據(jù)進(jìn)行排序。排序使用“選擇排序法”。國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷第6套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、已知數(shù)據(jù)文件in81.dat中存有300個(gè)4位數(shù),并已調(diào)用函數(shù)readDat()把這些數(shù)存入數(shù)組a中,請(qǐng)編制一函數(shù)isValue(),其功能是:求出千位數(shù)上的數(shù)加百位數(shù)上的數(shù)等于十位數(shù)上的數(shù)加個(gè)位數(shù)上的數(shù)的個(gè)數(shù)cnt,再求出所有滿足此條件的4位數(shù)的平均值pjz1,以及所有不滿足此條件的4位數(shù)的平均值pjz2,最后調(diào)用函數(shù)writeDat()把結(jié)果cnt,pjz1,pjz2輸出到out81.dar文件。例如:7153,7+1=5+3,則該數(shù)滿足條件,計(jì)算平均值pjz1,且個(gè)數(shù)cnt=cnt+1。8129,8+1≠2+9,則該數(shù)不滿足條件計(jì)算平均值pjz2。注意:部分源程序已給出。程序中已定義數(shù)組:a[300],b[300],已定義變量:cnt,pjz1,pjz2。請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)readDat()和寫函數(shù)writeDat()的內(nèi)容。試題程序:#include<stdio.h>inta[300],cnt=0;doublepjz1=0.0,pjz2=0.0;voidjsValue(){}main(){inti;readDat();jsValue();writeDat();printf("cnt=%d\n滿足條件的平均值pjz1=%7.21f\n不滿足條件的平均值pjz2=%7.21f\n",cnt,pjz1,pjz2);}readDat(){FILE*fp;inti;fp=fopen("in81.dat","r");for(i=0;i<300;i++)fscanf(fp,"%d,",&a[i]);fclose(fp);}writeDat(){FILE*fp;inti;fp=fopen("outSl.dat","w");fprintf(fp,"%d\n%7.21f\n%7.21f\n",cnt,pjz1,pjz2);fclose(fp);}標(biāo)準(zhǔn)答案:voidjsValue(){inti,thou,hun,ten,data,n=0;for(i=0;i<300;i++){thou=a[i]/1000;/*求四位數(shù)的千位數(shù)字*/hun;a[i]%1000/100;/*求四位數(shù)的百位數(shù)字*/ten=a[i]%100/10;/*求四位數(shù)的十位數(shù)字*/data;a[i]%10;/*求四位數(shù)的個(gè)位數(shù)字*/if(thou+hun==ten+data)/*如果千位數(shù)加百位數(shù)等于十位數(shù)加個(gè)位數(shù)*/{cnt++;/*統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/piz1+=a[i];/*將滿足條件的數(shù)求和*/}else{n++;/*否則統(tǒng)計(jì)不滿足條件的數(shù)的個(gè)數(shù)*/pjz2+;a[i];/*將不滿足條件的數(shù)求和*/}}pjz1/=cnt;/*求滿足條件的數(shù)的平均值*/pjz2/=n;/*求不滿足條件的數(shù)的平均值*/}知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:(1)特殊運(yùn)算符“%”及“/”的使用。(2)循環(huán)結(jié)構(gòu)及選擇結(jié)構(gòu)的使用。在本題中,首先要將一個(gè)4位數(shù)的千位、百位、十位、個(gè)位拆成獨(dú)立的數(shù)字。這里借助特殊運(yùn)算符號(hào)“%”——取余和“/”——整除,拆分方法略。然后判斷“千位數(shù)+百位數(shù)=十位數(shù)+個(gè)位數(shù)”。依次求得符合條件的數(shù)的個(gè)數(shù)及其平均值。國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷第7套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、已知在文件IN.dat中存有100個(gè)產(chǎn)品銷售記錄,每個(gè)產(chǎn)品銷售記錄由產(chǎn)品代碼code(字符型4位)、產(chǎn)品名稱name(字符型10位)、單價(jià)uprice(整型)、數(shù)量amount(整型)、金額sum(長(zhǎng)整型)5部分組成。其中:金額=單價(jià)×數(shù)量。函數(shù)Rdata()是讀取這100個(gè)銷售記錄并存入結(jié)構(gòu)數(shù)組sell中。請(qǐng)編寫函數(shù)SortDat(),其功能要求:按金額從小到大進(jìn)行排列,若金額相等,則按產(chǎn)品代碼從小到大進(jìn)行排列,最終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組sell中。最后調(diào)用函數(shù)Wdata(),把結(jié)果輸出到OUT.dat文件中。注意:部分源程序已經(jīng)給出。請(qǐng)勿改動(dòng)主函數(shù)main()、讀數(shù)據(jù)函數(shù)Rdata()和輸出數(shù)據(jù)函數(shù)Wdata()的內(nèi)容。#include<stdio.h>#include<string.h>#include<conio.h>#include<stdlib.h>#defineMAX100typedefstruct{charcode[5];/*產(chǎn)品代碼*/charname[11];/*產(chǎn)品名稱*/intuprice;/*單價(jià)*/intamount;/*數(shù)量*/longsum;/*金額*/}PRO;PROsell[MAX];voidRdata();voidWdata();voidSortDat(){}voidmain(){memset(sell,0,sizeof(sell)Rdata();SortDat();Wdata();}voidRdata(){FILE*fp;charstr[80],ch[11];inti;fp=fopen("IN.dat","r");for(i=0;i<100;i++){fgets(str,80,fp);memcpy(sell[i].code,str,4);memcpy(sell[i].name,str+4,10);memcpy(ch,str+14,4);ch[4]=0;sell[i].uprice=atoi(ch);memcpy(ch,str+18,5);ch[5]=0;sell[i].amount=atoi(ch);sell[i].sum=(long)sell[i].uprice*sell[i].amount;}fclose(fp);}voidWdata(){FILE*fp;inti;fp=fopen("OUT.dat","w");for(i=0;i<100;i++){printf("%s%s%4d%5d%5d\n",sell[i].code,sell[i].name,sell[i].uprice,sell[i].amount,sell[i].sum);fprintf(fp,"%s%s%4d%5d%5d\n",sell[i].code,sell[i].name,sell[i].uprice,sell[i].amount,sell[i].sum);}fclose(fp);}標(biāo)準(zhǔn)答案:voidSortDat(){inti,j;PROxy;for(i=0;i<99;i++)for(j=i+1;j<100;j++)if(sell[i].sum>sell[j].sum){xy=sell[i];sell[i]=sell[j];sell[j]=xy;}elseif(sell[i].sum==sell[j].sum){if(strcmp(sell[i].code,sell[j].code)>0){xy=sell[i];sell[i]=sell[j];sell[j]=xy;}}}[解題思路]這里我們通過(guò)一個(gè)雙重循環(huán)來(lái)實(shí)現(xiàn),首先按產(chǎn)品的金額進(jìn)行比較,如果前一個(gè)產(chǎn)品的金額大于后一個(gè)產(chǎn)品的金額,則這兩個(gè)產(chǎn)品進(jìn)行數(shù)據(jù)交換;如果兩個(gè)產(chǎn)品的金額相等,用字符串比較函數(shù)strcmp()比較兩個(gè)產(chǎn)品的產(chǎn)品代碼,如果前一個(gè)產(chǎn)品的代碼大于后一個(gè)產(chǎn)品的代碼,則這兩個(gè)產(chǎn)品進(jìn)行數(shù)據(jù)交換。知識(shí)點(diǎn)解析:暫無(wú)解析國(guó)家三級(jí)(數(shù)據(jù)庫(kù)技術(shù))機(jī)試模擬試卷第8套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、請(qǐng)編制函數(shù)ReadDat()實(shí)現(xiàn)從文件IN93.DAT中讀取1000個(gè)十進(jìn)制整數(shù)到數(shù)組xx中。請(qǐng)編制函數(shù)Compute()分別計(jì)算出xx中奇數(shù)的個(gè)數(shù)odd、偶數(shù)的個(gè)數(shù)even、平均值aver及方差totfc的值,最后調(diào)用函數(shù)WriteDat()把結(jié)果輸出到OUT93.DAT文件中。計(jì)算方差的公式如下:原始數(shù)據(jù)的存放格式是:每行存放10個(gè)數(shù),并用逗號(hào)隔開(kāi)(每個(gè)數(shù)均大于0且小于等于2000)。注意:部分源程序已給出。請(qǐng)勿改動(dòng)主函數(shù)main()和寫函數(shù)WriteDat()的內(nèi)容。試題程序:#include<stdio.h>#include<stdlib.h>#include<string.h>#defineMAX1000intxx[MAX],odd=0,even=0;doubleaver=0.0,totfc=0.0;voidWriteDat(void);intReadDat(void){FILE*fp;if((fp=fopen("IN93.DAT","r"))==NULLreturn1;fclose(fp);returnO;}voidCompute(void){}voidmain(){inti;for(i=O;i<MAX;i++)xx[i]=0;if(ReadDat()){printf("數(shù)據(jù)文件IN93.DAT不能打開(kāi)!\007\n");return;}Compute();printf("ODD=%d\nEVEN=%d\nAVER=%lf\nTOTFC=%lf\n",odd,even,aver,totfc);WriteDat();}voidWriteDat(void){FILE*fp;inti;fp=fopen("OUT93.DAT","w");fprintf(fp,"%dln%dln%lf\n%lfkn",odd,even,aver,totfc);fclose(fp);}標(biāo)準(zhǔn)答案:intReadDat(void){FILE*fp;inti,j;if((fP=fopen("IN93.DAT","r"))==NULL)return1;for(i=0;i<100;i++){for(j=0;j<10;j++)fscanf(fp,"%d,",&xx[i*10+j]);fscanf(fp,"\n");if(feof(fp))break;}fclose(fp);return0;}voidCompute(void){inti,yy[MAX];for(i=0;i<1000;i++){if(xx[i]%2!=0)odd++;/*求出xx中奇數(shù)的個(gè)數(shù)odd*/elseeven++;/*求出xx中偶數(shù)的個(gè)數(shù)even*/aver+=xx[i];/*求出xx中元素的總和*/}aver/=MAX;/*求出xx中元素的平均值*/for(i=0;i<1000;i++)totfc+=(xx[i]-aver)*(xx[i]-aver)/MAX;}知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:(1)從文件中讀取數(shù)據(jù)。(2)奇偶數(shù)的判斷和方差的求法。在C語(yǔ)言中,有一結(jié)構(gòu)體類型FILE,其中

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論