版權(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025寶雞市藝術(shù)劇院有限公司招聘考試重點(diǎn)試題及答案解析
- 2025年12月重慶市萬州區(qū)恒合土家族鄉(xiāng)便民服務(wù)中心公益性崗位招聘1人考試重點(diǎn)題庫及答案解析
- 2025年華中師范大學(xué)人工智能教育學(xué)部合同聘用制人員招聘備考題庫附答案詳解
- 2025河北雄安容和悅?cè)菪W(xué)見習(xí)崗招聘筆試重點(diǎn)題庫及答案解析
- 新能源汽車充電樁智能管理系統(tǒng)在2025年戶外活動(dòng)應(yīng)用場景可行性研究報(bào)告
- 支教 課程設(shè)計(jì)
- 2026江西銅業(yè)技術(shù)研究院有限公司北京分院院長社會(huì)招聘1人筆試重點(diǎn)題庫及答案解析
- 2025年民生銀行天津分行社會(huì)招聘備考題庫附答案詳解
- 2025年中國兵器工業(yè)集團(tuán)航空彈藥研究院有限公司公開招聘安全總監(jiān)備考題庫及一套答案詳解
- 河源市民政局2025年公開招聘編外人員備考題庫及一套參考答案詳解
- DB42-T 559-2022 低能耗居住建筑節(jié)能設(shè)計(jì)標(biāo)準(zhǔn)
- 【課件】共筑保密防線 公民人人有責(zé) 課件-2024-2025學(xué)年下學(xué)期全國保密宣傳教育月主題班會(huì)
- GB/T 4447-2025船舶與海洋技術(shù)海船起錨機(jī)和起錨絞盤
- 解直角三角形的實(shí)際應(yīng)用(8種題型)-2025年中考數(shù)學(xué)一輪復(fù)習(xí)(原卷版)
- 自然辯證法-2018版課后思考題答案
- 先天性食管閉鎖的護(hù)理
- 人教版七年級(jí)地理上冊知識(shí)點(diǎn)總結(jié)-七年級(jí)地理上冊知識(shí)點(diǎn)總結(jié)歸納
- 項(xiàng)目人員管理方案
- 《基于Java學(xué)生管理系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)》9500字(論文)
- 第二類精神藥品質(zhì)量管理制度
- 口袋公園設(shè)計(jì)方案
評(píng)論
0/150
提交評(píng)論