國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷13(共9題)_第1頁
國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷13(共9題)_第2頁
國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷13(共9題)_第3頁
國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷13(共9題)_第4頁
國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷13(共9題)_第5頁
已閱讀5頁,還剩4頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

家三級(jí)信息管理技術(shù)機(jī)試模擬試卷13

(共9套)

(共9題)

國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷第

1套

一、程序設(shè)計(jì)題(本題共[題,每題7.0分,共]分。)

1、己知在文件IN6.DAT中存有100個(gè)產(chǎn)品銷售記錄,每個(gè)產(chǎn)品銷售記錄由產(chǎn)品代

碼dm(字符型4位)、產(chǎn)品名稱me(字符型10位)、單價(jià)dj(整型)、數(shù)量si(整型)、

金額je(長整型)幾部分組成。其中:金額=單價(jià)x數(shù)量。函數(shù)ReadDal。的功能是讀

取這100個(gè)銷售記錄并存入結(jié)構(gòu)數(shù)組sell中。請編制函數(shù)SortDat。,其功能要求:

按產(chǎn)品名稱從小到大進(jìn)行排列,若產(chǎn)品名稱相同,則按金額從小到大進(jìn)行排列,最

終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組sell中,最后調(diào)用函數(shù)WriteDat。把結(jié)果輸出到文件

OUT6.DAT+o注意:部分源程序已給出。請勿改動(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>#define

MAX100typedefstructchardm[5];/*產(chǎn)品代碼*/charmc[ll];/*產(chǎn)品名稱*/intdj;/*

單價(jià)*/intsi;/*數(shù)量*/longje;/*金額*/}PRO:PROsell[MAX];voidReadDati);

voidWriteDat();voidSortDat(){}main(){memset(sell,0,sizeof(sell));ReadDat();

SortDat()WriteDat();}voidRcadDat(){FILE*fp;charstr[80],ch[lI];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[i].sl=atoi(ch);sell[i].je=(long)seil[i].dj

*sell[i].sl;)fclose(fp);}voidWriteDat(){FILE*fp;inti;fp=fopen("OUT6.DAT",

"wn);for(i=0;i<100;i++){fprintf(fp,H%s%s%4c%5d%101d\nH,sell[i].dm,

sell[i].me,sell[i].dj,sell[i].sl,sell[i].je);}fclose(fp);}

標(biāo)油答案:voidSortDatf){inti,j;PROxy;for(i=0;i<99;i++)for(j=i+l;j<100;j++)

if(strcmp(sell[i].me,sell[j].mc)>0)/*按產(chǎn)品名稱從小到大進(jìn)行排列東/{xy=sell[i];

sell[i]=sell[j];sell[j]=xy;)elseif(strcmp(sell[i].me,sell[j].mc)==0)/*若產(chǎn)品名稱相同

*/if(seH[i].je>seH(j].je)件則按金額從小到大進(jìn)行排列*/{xy=seH[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ù)sircmpO),則交換這兩個(gè)元素的位置,繼續(xù)和后面的其他元素進(jìn)行比較,最

終在第一個(gè)元素中存放的是產(chǎn)品名稱最小的元素。以此類推,就實(shí)現(xiàn)了從小到大排

序的功能。注意:這里要進(jìn)行交換的是兩個(gè)結(jié)構(gòu)體變量,而不是它們的某一個(gè)域,

因此,要借助第三個(gè)結(jié)溝體變量來充當(dāng)中間容器。若產(chǎn)品名稱相同,則要按照金額

從小到大進(jìn)行排序。

國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷第

2套

一、程序設(shè)計(jì)題(本題共1題,每題i.o分,共]分。)

1、已知在文件IN3.DAT中存有100個(gè)產(chǎn)品銷售記錄,每個(gè)產(chǎn)品銷售記錄由產(chǎn)品代

碼dm(字符型4位)、產(chǎn)品名稱me(字符型10位)、單價(jià)dj(整型)、數(shù)量si(整型)、

金額je(長整型)五部分組成。其中:金額=單價(jià)x數(shù)量。函數(shù)ReadDat()的功能是讀

取這100個(gè)銷售記錄并存入結(jié)構(gòu)數(shù)組.sell中。請編制函數(shù)SortDat。,其功能要求:

按產(chǎn)品名稱從小到大進(jìn)行排列,若產(chǎn)品名稱相同,則按金額從小到大進(jìn)行排列,最

終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組sell中,最后調(diào)用函數(shù)WriieDatO把結(jié)果輸出到文件

OUT3.DAT中。注意:部分源程序已給出。請勿改動(dòng)主函數(shù)main。、讀數(shù)據(jù)函數(shù)

ReadDat。和輸出數(shù)據(jù)函數(shù)WriteDat。的內(nèi)容。[試題程序]#include#include#include

#include#include#defineMAX100typedefstruct{chardm[5];/*產(chǎn)品代碼*/char

mc[H];/*產(chǎn)品名稱*/intdj;/*單價(jià)*/intE;/*數(shù)量啊longje;/*金額*/)PRO;PRO

sell[MAX];voidReadDat();voidWriteDat();voidSortDat())voidmain()

{memset(sell,0,sizeof(sell));ReadDat();SortDat();WritcDat();}voidRcadDat(){FILE

*fp;charstr[80],ch[ll];Inti;fp=fopen("IN3.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;scll[i].dj=atol(ch);memcpy(ch,str+18,5);ch[5]=0;

sell[i].sl=atol(ch);sell[i].je=(long)sell[i].dj*sell[i].sl;)fclose(fp);}voidWriteDat(void)

{FILE*fp;inii;fp=fopen(,,OUT3.DATn,',w");for(i=0;i<!00;i++)

fprintf(fp,"%s%s%4d%5d%101d\n",sell[i].dj,sell[i].sl,sell|i].je);

fclose(fp);}

標(biāo)準(zhǔn)答案;voidSortDat()(intij;PROxy;for(i=0;i<99;i++)for(j=i+l;j<100;j++)

{if(strcmp(sell[i].dm,sell[j].dm)<0)/*按產(chǎn)品代碼從大到小進(jìn)行排列*/

{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}elseif(strcmp(sell[i].dm,sell[j].dm)==O)/*若產(chǎn)品

代碼相同*/if(sell[i].jeVsell[j].je)/*則按金額從大到小進(jìn)行排列*/

{xy=sell[i];sell[i]=sell[j];sell[j]=xy;))}

知識(shí)點(diǎn)解析:此類題型考查的知識(shí)點(diǎn)包括以下幾方面:(1)結(jié)構(gòu)體數(shù)組的排序;(2)

結(jié)構(gòu)體及結(jié)構(gòu)體數(shù)組的相關(guān)操作;(3)字符型數(shù)組的比較;(4)C語言庫函數(shù)的使用

(如函數(shù)strcmp。)。此題是按產(chǎn)品代碼從大到小進(jìn)行排列,若產(chǎn)品代碼相同,則按

金額從大到小進(jìn)行排列,相應(yīng)語句為:if(strcmp(sell[i].dm,sell[j].dm)<

O)||((strcmp(sell[i].dm,sell[j].dm)==O)&&(sell[i].je<sell[j].je)))

國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷第

3套

一、程序設(shè)計(jì)題(本題共1題,每題1.0分,共7分。)

1、已知數(shù)據(jù)文件in80.dat中存有300個(gè)4位數(shù),并已調(diào)用函數(shù)readDat。把這些數(shù)

存入數(shù)組a中,請編制一函數(shù)jsValue。,其功能是:求出個(gè)位數(shù)上的數(shù)減千位數(shù)上

的數(shù)減百位數(shù)上的數(shù)減十位數(shù)上的數(shù)大于0的個(gè)數(shù)ent,再求出所有滿足此條件的

4位數(shù)平均值pjzl,以及所有不滿足此條件的4位數(shù)平均值pjz2,最后調(diào)用函數(shù)

writeDat。把結(jié)果ent,pjzl,pjz2輸出至Uout80.dat文件。例如;1239,9-1-2-3>

0,則該數(shù)滿足條件,并算平均值pjzl,且個(gè)數(shù)8129,9-8-1-2<0,則

該數(shù)不滿足條件,計(jì)算平均值pjz2。注意:部分源程序已給出。程序中己定義數(shù)

組:a[300],b[300],已定義變量:ent,pjzl,pjz2o請勿改動(dòng)主函數(shù)main。、讀

函數(shù)readDal。和寫函數(shù)wri【eDa【()的內(nèi)容。試題程序:#include<stdio.h>int

a[300],cnt=O;doublepjzl=0.0,pjz2=0.0;voidjsValueO{}main(){inti;readDat();

jsValue();writeDat();printf("cnt=%d\n滿足條件的平均橙pjzl=%7.21f\n不滿足條件

的平均值pjz2=%7.21f\n",cnt,pjzl,pjz2);}reaclDat(){FILE*fp;inti;

fp=fopen("in80.dat'\"r"):for(i=0;i<300;i++)fscanf(fp,"%d,",&a[i])fclose(fp);)

writeDat(){FILE*fp;inti;fp=fopen("out80.dat","w")

fprintf(fp,"%d\n%7.21f\n%7.21f\n",cnt,pjzl,pjz2);fclose(fp);)

標(biāo)準(zhǔn)答案:voidjsValueQ{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(data-thou-hun-ten>0)/*如果個(gè)位數(shù)減千位數(shù)減百位數(shù)減十位數(shù)大于0*/

{cnt++;/*統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/pizl+=a[i];/*將滿足條件的數(shù)求和*/}else

{n++;/*否則統(tǒng)計(jì)不滿足條件的數(shù)的個(gè)數(shù)*/piz2+=a[i];/*將不滿足條件的數(shù)求和

*/))pjzl/二cnl;/*求滿足條件的數(shù)的平均值*/pjz2/二n;/*求不滿足條件的數(shù)的平均值

*/}

知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:⑴特殊運(yùn)算符"%''及的使用。(2)循環(huán)

結(jié)構(gòu)及選擇結(jié)構(gòu)的使用。在本題中,首先要將一個(gè)4位數(shù)的千位、百位、十位、

個(gè)位拆成獨(dú)立的數(shù)字。這里借助特殊運(yùn)算符號(hào)“%”(取余)和(整除),拆分方法

略。然后判斷“個(gè)位數(shù)一千位數(shù)-百位數(shù)-十位數(shù)”的值是否大于0。依次求得符合條件

的數(shù)的和及其平均值。

國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷第

4套

一、程序設(shè)計(jì)題(本題共[題,每題1.0分,共7分。)

1、下列程序的功能是:利用以下所示的簡單迭代方法求方程:cos(x)-x=0的一個(gè)實(shí)

根。xn+l=cos(xn)迭代步驟如下;⑴取xl初值為0.0。(2)x0=xl,把xl的值賦給

xOo(3)xl=cos(x0),求出一個(gè)新的xl。(4)若x0?xl的絕對(duì)值小于0.000001,執(zhí)行

步驟(5),否則執(zhí)行步驟⑵。(5)所求xl就是方程cos(x)-x=0的一個(gè)實(shí)根,作為函

數(shù)值返回。請編寫函數(shù)countValuc。實(shí)現(xiàn)程序要求,最后調(diào)用函數(shù)writcDAT。把結(jié)

果輸出到文件out41.dat中。注意;部分源程序已給出。請勿改動(dòng)主函數(shù)main。和

月函數(shù)writeDAT。的內(nèi)容.試題程序:#include<conio.h>#inckide<math.h>

#include<stdio.h>floatcountValue(){}main(){clrscr();printf("實(shí)根

=%f\n'\countValue());printf("%f\n",cos(countValue())-countValue());writcDAT();}

writeDAT(){FILE*wf;wf=fopen("out41.dat",,Hw");fprintf(wf,"%An",countValue());

fclose(wf);}

標(biāo)準(zhǔn)答案:floatcountValue(){floatxO,xl=0.0:while(l){x0=xl;/*將xl賦值給

x0*/xl=cos(x0);/*求出新的xI*/if(fabs(x0-xl)Vle-6)break;/*若xO-xl的絕對(duì)值

小于0.000001,則結(jié)束循環(huán)*/}returnxl;)

知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:(1)數(shù)學(xué)函數(shù)doublecos(doublex)及double

fabs(doublex)的使用。(2)使用循環(huán)結(jié)構(gòu)實(shí)現(xiàn)迭代。在本題中,因?yàn)橐笠粋€(gè)實(shí)數(shù)

的余弦值,在結(jié)束迭代的時(shí)候要判斷絕對(duì)值,所以這里要用到數(shù)學(xué)函數(shù)cos(double

x)和fabs(doublex)。先設(shè)一個(gè)條件永遠(yuǎn)為真的while循環(huán)結(jié)構(gòu),按照步驟提示,要

先為xl取初值,將xl的值賦給x0,使xl=cos(x0),判斷x0-xl的絕對(duì)值將其作為

強(qiáng)行退出循環(huán)的條件。

國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷第

5套

一、程序設(shè)計(jì)題(本題共7題,每題7.0分,共I分0)

1、已知文件IN16.DAT中存有100個(gè)產(chǎn)品銷售記錄,每個(gè)產(chǎn)品銷售記錄由產(chǎn)品代

碼dm(字符型4位)、產(chǎn)品名稱me(字符型10位)、單價(jià)dj(整型)、數(shù)量si(整型)、

金額jc(長整型)幾部分組成。其中;金額=單價(jià)x數(shù)量。函數(shù)RcadDat。的功能是讀

取這100個(gè)銷售記錄并存入結(jié)構(gòu)數(shù)組sell中。請編制函數(shù)SortDal。,其功能要求:

按產(chǎn)品名稱從大到小進(jìn)行排列,若產(chǎn)品名稱相同,則按金額從大到小進(jìn)行排列,最

終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組sell中,最后調(diào)用函數(shù)WriteDatO把結(jié)果輸出到文件

OUT16.DAT中。注意:部分源程序已給出。請勿改動(dòng)主函數(shù)main。、讀函數(shù)

ReadDat。和寫函數(shù)WriteDat。的內(nèi)容。試題程序:#inckide<stdio.h>#include<

mem.h>#include<string.h>#include<conio.h>#include<stdlib.h>#define

MAX100typedefstruct{chardm[5];/*產(chǎn)品代碼*/charmc[l1];/*產(chǎn)品代碼*/intdj;

/*單價(jià)*/intsi;/*數(shù)量*/longje;/*金額*/}PRO;PROsell[MAX];voidReadDat();

voidWriteDatO;voidSortDat(){}main(){memset(sell,0,sizeof(sell));ReadDat();

SortDat();WriteDat();}voidReadDat(){FILE*fp;charstr[80],ch[l1];inti;fp=

fopen("IN16.DATM,"rH);for(i=0;i<I00;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;sellfil.dj=

atoi(ch);memcpy(ch,str+18,5);ch[5]=0;sell[i].si=atoi(ch);sell[i].je=

(long)sell[i].dj*sellfi].si;}fclose(fp);)voidWriteDatO{FILE*fp;inti;fp=

fopen("OUTI6.DATn,nw");for(i=0;i<100;i++){fprintf(fp,

"%s%s%4d%5d%101d\n';sell[ij.dm.sell[i].mc.sell[i].dj,selllij.si,sell[i].je);}

fclose(fp);}

標(biāo)準(zhǔn)答案:voidSortDat(){inti,j;PROxy;for(i=0;i<MAX-l;i++)for(j=i+l;j<

MAX;j++)if(stremp(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].me,.mc)==0)/*若

產(chǎn)品名稱相同,則按金額從大到小進(jìn)行排列*/if(scll[i].jc<scll[j].jc){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)位置的字符的ASCH碼小(這里用到

了字符串比較函數(shù)sircmpO),則交換這兩個(gè)元素的位置.,繼續(xù)和后面的其他元素進(jìn)

行比較,最終在第一個(gè)元素中存放的是產(chǎn)品名稱最大的元素。以此類推,就實(shí)現(xiàn)了

從大到小排序的功能。注意:這里要進(jìn)行交換的是兩個(gè)結(jié)構(gòu)體變量,而不是它們

的某一個(gè)域,因此,要借助第三個(gè)結(jié)構(gòu)體變量來充當(dāng)中間容器。若發(fā)現(xiàn)產(chǎn)品名稱是

相同的,則要按照金額從大到小進(jìn)行排序。

國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷第

6套

一、程序設(shè)計(jì)題(本題共I題,每題i.o分,共1分。)

1、函數(shù)ReadDat。的功能是實(shí)現(xiàn)從文件ENG98.IN中讀取一篇英文文章,存入到字

符串?dāng)?shù)組xx中。請編制函數(shù)encryChar。,按給定的替代關(guān)系對(duì)數(shù)組xx中所有字符

進(jìn)行替代,仍存入數(shù)組xx的對(duì)應(yīng)的位置上,最后調(diào)用函數(shù)WritcDat。把結(jié)果xx輸

出到文件ps98.dat中。替代關(guān)系,f(p)=p*l1mod256(p是數(shù)組xx中某一個(gè)字符的

ASCII值,f(p)是計(jì)算后新字符的ASCH值),如果計(jì)算后f(p)的值小于等于32或其

ASCII值是奇數(shù),則該字符不變,否則將f(p)所對(duì)應(yīng)的字符進(jìn)行替代。注意:部分

源程序已給出。原始數(shù)據(jù)文件的存放格式是每行的寬度均小于80個(gè)字符。請勿改

動(dòng)主函數(shù)main。、讀函數(shù)ReadDat。和寫函數(shù)WriteDat。的內(nèi)容。試題程序:

#include<conio.h>#include<stdio.h>#include<string.h>#include<ctype.h>

unsignedcharxx|50|[80|;intmaxline=0;intReadDat(void);voidWriteDat(void);void

encryChar(){)voidmain({clrscr();if(ReadDat()){printf("數(shù)據(jù)文件ENG98.IN不能

打開!\n\007");return;}encryChar();WriteDat();}intRcadDat(void){FILE*fp;int

i=0;unsignedchar*p;if((fp=fopen(,'ENG98.IN';',r,'))==NULL)return1;

whilc(fgcts(xx[i],80,fp)!=NULL){p=strchr(xx[i];\n,);if(p)*p=0;i++;}maxline=i;

fclose(fp);return0;}voidWriteDat(){FILE*fp;inti;fp=fopen("ps98.dat',,"w'');

for(i=0;i<maxline;i++){printf("%s\n",xx[i]);fprintf(fp,"%s\n'\xx[i]);}fclose(fp);)

標(biāo)準(zhǔn)答案:voidcncryChar(){inti;char*pr;for(i=0;i<maxline;i++){pf=xx[i];/*指

針pf指向該行第一個(gè)字符*/while(*pf!=0){if((*pf*l1%256)%2!=O||*pf*ll%256<

=32){/*如果計(jì)算后的值小于等于32或其ASCII值是奇數(shù)*/pf++;/*則不做改變,

指向下一個(gè)字符*/continue;/*退出本次循環(huán)*/}*pf=*pf*l1%256;/*否則用新字符取

代原有字符*/pf++;/*指向下一個(gè)字符*/})}

知識(shí)點(diǎn)解析:本題考查的知識(shí)點(diǎn)如下:(1)字符對(duì)應(yīng)的ASCH碼。(2)判斷結(jié)構(gòu)中多

個(gè)條件的“或”運(yùn)算。⑶退出一次循環(huán)。(4)二維數(shù)組的訪問。在C語言中,字符

可參與任何整數(shù)運(yùn)算。實(shí)際上,是字符的ASCII碼參與了運(yùn)算。所以可以直接用

字符代入f(p)的關(guān)系式口求出替換字符。若f(p)W32或其ASCII值為奇數(shù),則該字

符不變。兩條件滿足一個(gè)即可,所以這兩個(gè)條件之間用“或”運(yùn)算。一個(gè)數(shù)除以2取

余所得的數(shù)不為0,則此數(shù)為奇數(shù)。若字符不變,則可不必計(jì)算替換字符,使用

ccntinue跳出本次循環(huán),進(jìn)入下一次循環(huán)的條件判斷中.因?yàn)檫@里不是直接退出循

環(huán)結(jié)構(gòu),所以不能使用break語句。本題中,將數(shù)據(jù)存放在一個(gè)二維數(shù)組中,可以

定義一個(gè)指向數(shù)組每一行的指針。初始時(shí),指針指向該行的第一個(gè)元素,隨著地址

增加,指針指向后面的元素。

國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷第

7套

一、程序設(shè)計(jì)題(本題共7題,每題7.0分,共[分0)

1、已知IN7.DAT中存有200個(gè)4位數(shù),并已調(diào)用讀函數(shù)readDat。把這些數(shù)存入數(shù)

組a中,請編制一函數(shù)jsVal(),其功能是:依次從數(shù)組a中取出一個(gè)數(shù),如果該4

位數(shù)連續(xù)大于該4位數(shù)以后的5個(gè)數(shù)且該數(shù)是奇數(shù),則統(tǒng)計(jì)出滿足此條件的數(shù)的個(gè)

數(shù)cn【,并把這些4位數(shù)按從小到大的順序存入數(shù)組b中,最后調(diào)用寫函數(shù)

writeDat。把結(jié)果ent及數(shù)組b中符合條件的4位數(shù)輸出到OUT7.DAT文件中。注

意:部分源程序已給出。程序中已定義數(shù)組:a[200],b[200],已定義變量:ent。

請勿改動(dòng)主函數(shù)main。、讀函數(shù)readDat。和寫函數(shù)writeDat。的內(nèi)容。試題程序:

#include<stdio.h>#defineMAX200inta[MAX],b[MAX],ent=0;voidwriteDaO;

voidjsVal(){voidreadDat(){inti;FILE*fp;fp=fopenC'IN7.DAT","r");for(i=0;i

<MAX;i++)fscanf(fp,"%d",&a|i|);close(fp);}main(){inti;readDat();jsVal();

printf("滿足條件的數(shù)二%d\n",ent);for(i=0;i<ent;i-+)printf("%d",b[i]);printf

(“\n");writeDat();}voidwriteDat(){FILE*fp;inti;fp=fopen(,,OUT7.DAT\"wn);

fprintf(fp,"%d\nn,ent);for(i=0;i<ent;i++)fprintf(fp,"%d\n",b[i]);fclose(fp);}

標(biāo)準(zhǔn)答案:voidjsVal(){inti,j,flag=O;intk;for(i=0;i<MAX-5;i++){for(j=i+l;j

V=i+5;j++)/*如果當(dāng)前數(shù)比后面的5個(gè)數(shù)都大,則給標(biāo)志變量flag賦值1*/{if

(a[i]>a|j])flag=1;else{flag=O;brcak:}/*否則給標(biāo)志變量flag賦值0并退出循環(huán)*/

if(a[i]%2==0)/*如果該數(shù)是偶數(shù),也給標(biāo)志變量flag賦值0*/flag=0;}if(flag==l>

/*將滿足條件的數(shù)存入數(shù)組b中,并統(tǒng)計(jì)滿足條件的數(shù)的個(gè)數(shù)*/

{b[cnt]=a[i];cnt十十;})for(i=0;i<cnt-l;i++)/?利用選擇法對(duì)b數(shù)組中的元素進(jìn)行

從小到大的排序*”0「。=1+1」<加4++)1"皿]>如[){1<="口;b[i]=b[j];b[j]=k;}}

知識(shí)點(diǎn)解析:根據(jù)題意可知,要編制函數(shù)的功能有兩部分:一是找出滿足條件的4

位數(shù),二是對(duì)找出的數(shù)進(jìn)行從小到大排序。首先利用一個(gè)f。「循環(huán)來依次從數(shù)組中

取得4位數(shù),接著用當(dāng)前得到的4位數(shù)與該數(shù)后面的5個(gè)數(shù)依次進(jìn)行比較,如果該

數(shù)比后面的5個(gè)數(shù)都大,則給標(biāo)志變量flag賦值1,接著對(duì)Hag進(jìn)行判斷,如果不

為1,則該數(shù)肯定不符合條件,直接去取下一個(gè)數(shù),若flag值為I,再來判斷該數(shù)

是否是奇數(shù),如果該數(shù)又是奇數(shù),則把該數(shù)加入到數(shù)組b中。這樣就可以依次取出

符合條件的數(shù)。然后利用選擇法對(duì)b數(shù)組中的元素進(jìn)行從小到大的排序。

國家三級(jí)信息管理技術(shù)機(jī)試模擬試卷第

8套

一、程序設(shè)計(jì)題(本題共,題,每題1.0分,共7分。)

1、已知在文件IN6.DAT中存有100個(gè)產(chǎn)品銷售記錄,每個(gè)產(chǎn)品銷售記錄由產(chǎn)品代

碼dm(字符型4位)、產(chǎn)品名稱me(字符型10位)、單價(jià)dj(整型)、數(shù)量si(整型)、

金額je(長整型)五部分組成。其中:金額=單價(jià)x數(shù)量。函數(shù)ReadDat。的功能是讀

取這100個(gè)銷售記錄并存入結(jié)構(gòu)數(shù)組sell中。請編制函數(shù)SortDat。,其功能要求:

按產(chǎn)品代碼從小到大進(jìn)行排列,若產(chǎn)品代碼相同,則按金額從小到大進(jìn)行排列,最

終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組sell中,最后調(diào)用函數(shù)WriieDat。把結(jié)果輸出到文件

OUT6.DAT中。注意:部分源程序已給出。請勿改動(dòng)主函數(shù)main。、讀數(shù)據(jù)函數(shù)

ReadDat。和輸出數(shù)據(jù)函數(shù)WriteDat。的內(nèi)容。[試題程序]#include#Includc#includc

#include#include#defineMAX100typedefstruct{chardm|5]/*產(chǎn)品代碼*/char

mc[l1]/*產(chǎn)品名稱刃intdj;/*單價(jià)*/intsi;/*數(shù)量*/longje;/*金額*/(PRO;PRO

sell[MAX];voidReadDat();voidWriteDat();voidSortDat(){}voidmain()

{memset(sell,0,sizeof(sell));ReadDat();SorrDat();WriteDat();}voidReadDat(){FILE

*fp;charstr[80],ch|111;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);

ineincpy(cli,sti+14,4);ch|4J-0;sell|i|.dj-aloi(cli);ineincpy(cli,sti+18,5);ch[5]-0;

sell[i].sl=atoi(ch);sell[i].je=(long)sell[i].dj*sell[i].sl;)fclose(fp);}voidWrileDat(void)

{FILE*fp;inti;fp=fopen(',OUT6.DAT,\"wn);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<MAX-l;i++)for(j=i+l;j<

MAX;j++){if(strcmp(sell[i].dm,sell[j].dm)>0)/*按代碼從小到大進(jìn)行排列*/

{xy=sell[i];sell[i]=sell[j];sell[j]=xy;}elseif(slrcmp(sell[i].dm,sell[j].dm)==O)/*若代碼

相同*/if(sen[i].je>sen(j].je)/*則按金額從小到大進(jìn)行排列*/

{xy=sell[i];sell[i]=sell[j];sell[j]=xy;))}

知識(shí)點(diǎn)解析:此題型考查的知識(shí)點(diǎn)包括以下幾方面:(1)結(jié)構(gòu)體數(shù)組的排序;(2)結(jié)

構(gòu)體及結(jié)構(gòu)體數(shù)組的相關(guān)操作;(3)字符型數(shù)組的比較;(4)C

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(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)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論