國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷11(共9題)_第1頁
國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷11(共9題)_第2頁
國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷11(共9題)_第3頁
國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷11(共9題)_第4頁
國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷11(共9題)_第5頁
已閱讀5頁,還剩9頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷11(共9套)(共9題)國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷第1套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、標(biāo)準(zhǔn)答案:知識(shí)點(diǎn)解析:通過審題可以發(fā)現(xiàn)僅有一個(gè)不同點(diǎn),即要求統(tǒng)計(jì)的四位數(shù)的條件是“個(gè)位+千位=百位+十位”,參考答案的第8條語句,修改if條件語句的判斷條件即可,對(duì)于數(shù)據(jù)交換的整型變量tmp可以自定義其變量名。國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷第2套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、已知在文件IN6.DAT中存有100個(gè)產(chǎn)品銷售記錄,每個(gè)產(chǎn)品銷售記錄由產(chǎn)品代碼dm(字符型4位)、產(chǎn)品名稱mc(字符型10位)、單價(jià)dj(整型)、數(shù)量sl(整型)、金額je(長整型)幾部分組成。其中:金額=單價(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é)果輸出到文件OUT6.DAT中。注意:部分源程序已給出。請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)ReadDat()和寫函數(shù)WriteDat()的內(nèi)容。試題程序:#include<stdio.h>#include<mem.h>#include<string.h>#include<conio.h>#include<stdlib.h>#defineMAX100typedefstruct{chardm[5];/*產(chǎn)品代碼*/charmc[il];/*產(chǎn)品名稱*/intdj;/*單價(jià)*/ihtsl;/*數(shù)量*/longSe;/*金額*/}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("IN6.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);chi4]=0;sell[i].dj=atoi(ch);memcpy(ch,str+18,5);chi5]=0;sell[ii.sl=atoi(ch);sell[i].je=(long)sell[i].dj*sell[i].sl;}fclose(fp);}voidWriteDat(){FILE*fp;inti;fp=fopen("OUT6.DAT","w");for(i=0;i<100;i++){fprintf(fp,"%s%s%4d%5d%101d\n",sell[ii.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=O;i<99;i++)for(j=i+1;j<100;i++)if(strcmp(sell[i).mc,sell[j].mc)>0)/*按產(chǎn)品名稱從小到大進(jìn)行排列*/{xy=sell[i];sell[i]=sell[i];sell[j]=xy;}elseif(strcmp(sell[i].mc,sell[j]/mc)==0)/*若產(chǎn)品名稱相同*/if(sell[i].ie>sell[j].je)/*則按金額從小到大進(jìn)行排列*/{xy=sell[i];sell[i]=sell[j];sell[j]=xy;)}知識(shí)點(diǎn)解析:本題是有關(guān)結(jié)構(gòu)體數(shù)組的排序問題,可以用選擇法來實(shí)現(xiàn)。用第一個(gè)元素的產(chǎn)品名稱依次和它后面的元素的產(chǎn)品名稱進(jìn)行比較,如果發(fā)現(xiàn)當(dāng)前元素的產(chǎn)品名稱比后面的某個(gè)元素的產(chǎn)品名稱對(duì)應(yīng)字符的ASCII碼大(這里用到了字符串比較函數(shù)strcmp()),則交換這兩個(gè)元素的位置,繼續(xù)和后面的其他元素進(jìn)行比較,最終在第一個(gè)元素中存放的是產(chǎn)品名稱最小的元素。以此類推,就實(shí)現(xiàn)了從小到大排序的功能。注意:這里要進(jìn)行交換的是兩個(gè)結(jié)構(gòu)體變量,而不是它們的某一個(gè)域,因此,要借助第三個(gè)結(jié)構(gòu)體變量來充當(dāng)中間容器。若產(chǎn)品名稱相同,則要按照金額從小到大進(jìn)行排序。國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷第3套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、請(qǐng)編寫函數(shù)countValue(),其功能是;選出100~1000M的所有個(gè)位數(shù)字與十位數(shù)字之和被10除所得余數(shù)恰是百位數(shù)字的素?cái)?shù)(如191)。計(jì)算并輸出上述這些素?cái)?shù)的個(gè)數(shù)count,以及這些素?cái)?shù)值的和sum。函數(shù)WriteData()負(fù)責(zé)把結(jié)果輸出到OUT.DAT文件中。注意;部分源程序已給出。請(qǐng)勿改動(dòng)主函數(shù)main()和寫函數(shù)WriteData()的內(nèi)容。試題程序;#includeintcount,sum;voidWriteData();voidcountValue(){}voidmain(){count=sum=0;countValue();printf("count=%d,sum=%d\n",count,sum);WriteData();}voidWriteData(){FILE*fp;fp=fopen("OUT.DAT","w");fprintf(fp,"%d\n%d\n",count,sum);fclose(fp);}標(biāo)準(zhǔn)答案:voidcountValue(){inti,j,d[3],flag;for(i=100;i<1000;i++){flag=0;for(j=2;j知識(shí)點(diǎn)解析:本題主要考查素?cái)?shù)的判斷及數(shù)位分解問題。1.判斷是否為素?cái)?shù);素?cái)?shù)的定義是;若一個(gè)數(shù)除了其自身和1再?zèng)]有其他的除數(shù),則該數(shù)就是素?cái)?shù)。故用其定義可以很容易判斷。在2到所判斷數(shù)之間的數(shù)進(jìn)行掃描,若有一個(gè)除數(shù),則該數(shù)就不是素?cái)?shù)。2.?dāng)?shù)位分解;將n位數(shù)上各個(gè)位上的數(shù)值單獨(dú)分離出來。解決此問題的方法是;將n位數(shù)對(duì)10求余可以將個(gè)位上的數(shù)值分離出來。將這個(gè)n位數(shù)除以10以后得到一個(gè)n-1位數(shù),則此時(shí)n位數(shù)原來的10位就變成了n-1位數(shù)的個(gè)位,再將此n-1位數(shù)對(duì)10求余便可得到原n位數(shù)的十位。依此類推,按照同樣的方法便可將n位數(shù)各個(gè)位上的數(shù)值分離出來。國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷第4套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、標(biāo)準(zhǔn)答案:知識(shí)點(diǎn)解析:通過審題可以發(fā)現(xiàn)主要是排序條件的設(shè)置要求有所不同,參考答案的第8行進(jìn)行修改即可。國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷第5套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、已知在文件in70.dat中存有若干個(gè)(個(gè)數(shù)<200)4位數(shù)字的正整數(shù),函數(shù)ReadDat()是讀取這若干個(gè)正整數(shù)并存入數(shù)組xx中。請(qǐng)編制函數(shù)CalValue(),其功能要求是:(1)求出這個(gè)文件中共有多少個(gè)正整數(shù)totNum。(2)求這些數(shù)右移一位后,產(chǎn)生的新數(shù)是奇數(shù)的數(shù)的個(gè)數(shù)totCnt,以及滿足此條件的這些數(shù)(右移前的值)的算術(shù)平均值totPjz。最后調(diào)用函數(shù)WriteDat()把所有結(jié)果輸出到文件out70.dat中。注意:部分源程序己給出。請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)ReadDat()和寫函數(shù)WriteDat()的內(nèi)容。試題程序:#include<stdio.h>#include<conio.h>#defineMAXNUM200ihtxx[MAXNUM];inttotNum=0;inttotCnt=0;doubletotPjz=0.0;intReadDat(void);voidWriteDat(void);voidCalValue(void){}voidmain(){inti;clrscr();for(i=0;ixx[i]=0;if(ReadDat()){printf("數(shù)據(jù)文件IN70.DAT不能打開!\007\n");return;}CalValue();printf("文件IN70.DAT中共有正整數(shù)=%d個(gè)\n",totNum);printf("符合條件的正整數(shù)的個(gè)數(shù)=%d個(gè)\n",totCnt);printf("平均值=%.21f\n",totPjz);WriteDat();intReadDat(void){FILE*fp;ihti=0;if((fp=fopen("IN70.DAT","r"))==NULL)return1;while(!feof(fp)){fscanf(fp,"%d",&xx[i++]);}fclose(fp);return0;}voidWriteDat(void){FILE*fp;fp=fopen("OUT70.DAT","w");fprintf(fp,"%d\n%d\n%.21f\n",totNum,totCnt,totPjz);fclose(fp);}標(biāo)準(zhǔn)答案:voidCalValue(void){inti,data;for(i=0;i{if(!xx[i])break;/*如果數(shù)為0,則表示數(shù)組存的數(shù)已經(jīng)結(jié)束,退出循環(huán)*/if(xx[i]>0)totNum++;/*統(tǒng)計(jì)正整數(shù)的個(gè)數(shù)*/data=xx[i]>>1;/*將數(shù)右移一位*/if(data%2)/*如果產(chǎn)生的新數(shù)是奇數(shù)*/{totCnt++;/*統(tǒng)計(jì)滿面足條件的數(shù)的個(gè)數(shù)*/totPjz+=xx[i];/*求滿足條件的數(shù)的總和*/}}totPjz/=totCnt;/*求滿足條件的數(shù)的平均值*/知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:(1)右移運(yùn)算符“>>”的使用。(2)數(shù)組結(jié)束的判斷和強(qiáng)行退出一層循環(huán)結(jié)構(gòu)。(3)特殊運(yùn)算符“%”的使用。在本題中,并沒有給出確切的數(shù)據(jù)個(gè)數(shù),足以數(shù)據(jù)的最大個(gè)數(shù)定義的數(shù)組。在主函數(shù)中,給所有的數(shù)組成員賦初值為0,而從文件中讀取得數(shù)據(jù)是正整數(shù),所以只要數(shù)組的某個(gè)元素為0,則說明數(shù)組存的數(shù)據(jù)已經(jīng)結(jié)束。此時(shí)就可以結(jié)束循環(huán)結(jié)構(gòu)。這里要使用右移運(yùn)算符實(shí)現(xiàn)數(shù)據(jù)的右移位,右移運(yùn)算符是雙目運(yùn)算符。運(yùn)算符左側(cè)是要移的數(shù)據(jù),右側(cè)是移動(dòng)的位數(shù)。右側(cè)移出的數(shù)據(jù)(低位數(shù)據(jù))舍棄。1個(gè)數(shù)除以2取余所得的數(shù)是1,則這個(gè)數(shù)足奇數(shù)。國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷第6套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、已知數(shù)據(jù)文件IN39.DAT中存有300個(gè)四位數(shù),函數(shù)ReadData()負(fù)責(zé)把這些數(shù)存人數(shù)組inBuf[]中,請(qǐng)編制一函數(shù)findValue(),其功能是;求出這些四位數(shù)中是素?cái)?shù)的個(gè)數(shù)count,再求出所有滿足此條件的四位數(shù)的平均值averagel,以及所有不滿足此條件的4位數(shù)的平均值average2,并通過函數(shù)WriteData()把結(jié)果輸出到0UT.DAT文件中。例如;3191是素?cái)?shù),則該數(shù)滿足條件,計(jì)算平均值averagel,且個(gè)數(shù)count=count+l。1234是非素?cái)?shù),則該數(shù)不滿足條件,計(jì)算平均值average2。注意;部分源程序已給出。程序中已定義數(shù)組;inBuf[300],outBuf[300],已定義變量;count。請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)ReadData()和寫函數(shù)WriteData()的內(nèi)容。試題程序;#include#defineNUM300intinBuf[NUM],count=0;doubleaveragel=0,average2=0;voidReadData();voidWriteData();voidfindValue(){}voidmain(){ReadData();findValue();WriteData();printf("count=%d\naveragl=%7.21fknaverag2=%7.21fkn",count,averagel,average2);}voidReadData(){FILE*fp;inti;fp=fopen("IN.DAT","r");for(i=0;i標(biāo)準(zhǔn)答案:voidfindValue(){inti,j,flag,count_no=0;for(i=0;i知識(shí)點(diǎn)解析:本題主要考查素?cái)?shù)的判斷和平均值計(jì)算問題。1.判斷是否為素?cái)?shù);素?cái)?shù)的定義是;若一個(gè)數(shù)除了其自身和1再?zèng)]有其他的除數(shù),則該數(shù)就是素?cái)?shù)。故用其定義可以很容易判斷。在2到所判斷數(shù)之間的數(shù)進(jìn)行掃描,若有一個(gè)除數(shù),則該數(shù)就不是素?cái)?shù)。2.求平均值;由于本題中的數(shù)據(jù)量比較大,若采用先將各個(gè)值加起來再除以總個(gè)數(shù)來取平均的話,變量不能存儲(chǔ)那么大的數(shù)據(jù)而導(dǎo)致溢出。本題的程序采用的方法是;N個(gè)數(shù)的平均值=[前(N-1)個(gè)數(shù)的平均值*(N-1)+第N個(gè)數(shù)]/N,采用這種遞推的方法就避免了將大的數(shù)據(jù)存入變量中而產(chǎn)生溢出。國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷第7套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、文件IN.DAT中存有一篇英文文章,函數(shù)ReadData()負(fù)責(zé)將IN.DAT中的數(shù)據(jù)讀到數(shù)組inBuf[][]中。請(qǐng)編制函數(shù)replaceChar(),該函數(shù)的功能是按照指定規(guī)則對(duì)字符進(jìn)行替換。變換后的值仍存人inBuf[][]中。函數(shù)WriteData()負(fù)責(zé)將inBuf[][]中的數(shù)據(jù)輸出到文件OUT.DAT中并且在屏幕上打出。替換規(guī)則為;先對(duì)字符的ASCII碼按公式y(tǒng)=(a*11)mod256進(jìn)行運(yùn)算(a為某一字符的ASCII碼值,y為變換后的ASCII碼值),如果計(jì)算后y的值小于等于32或大于130,則字符保持不變,否則用y代替a。注意;部分源程序已給出。原始數(shù)據(jù)文件存放的格式是;每行的寬度均小于80個(gè)字符。請(qǐng)勿改動(dòng)主函數(shù)main()、讀函數(shù)ReadData()和寫函數(shù)WriteData()的內(nèi)容。試題程序;#include#include#include#include#defineLINE50#defineCOL80charinBuf[LINE][COL+1];inttotleLine=0;//文章的總行數(shù)intReadData(void);voidWriteData(void);voidreplaceChar(){}voidmain(){system("CLS");if(ReadData()){print{("IN.DATcan’tbeopen!\n\007");return;}replaceChar();WriteData();}intReadData(void){FILE*fp;inti=0,j=0;char*P;if((fp={open("IN.DAT","r"))==NULL)return1;while({gets(inBuf[i],COL+1,fp)!=NULL){p=strchr(inBuf[i],’\n’);if(p)*p=’\0’;i++;}totleLine=i;fclose(fp);return0;}voidWriteData(void){FILE*fp;inti;fp=fopen("OUT.DAT","w");for(i=0;i標(biāo)準(zhǔn)答案:voidreplaceChar(){inti,j,len;chary;for(i=0;i130)continue;elseinBuf[i][j]=y;//按條件來轉(zhuǎn)換}}}知識(shí)點(diǎn)解析:本題主要考查字符與其對(duì)應(yīng)的ASCII碼之間的轉(zhuǎn)換及對(duì)ASCII碼進(jìn)行操作。先計(jì)算出每行字符串的長度,再根據(jù)替換規(guī)則進(jìn)行相應(yīng)的替換。國家三級(jí)(網(wǎng)絡(luò)技術(shù))機(jī)試模擬試卷第8套一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共1分。)1、標(biāo)準(zhǔn)答案:知識(shí)點(diǎn)解析:①因?yàn)橐M(jìn)行字符之間的互換,所以定義局部字符變量ch。定義循環(huán)變量i、j、k。②在第一層for循環(huán)中

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(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)論