三級數(shù)據(jù)庫技術(shù)南開100題_第1頁
三級數(shù)據(jù)庫技術(shù)南開100題_第2頁
三級數(shù)據(jù)庫技術(shù)南開100題_第3頁
三級數(shù)據(jù)庫技術(shù)南開100題_第4頁
三級數(shù)據(jù)庫技術(shù)南開100題_第5頁
已閱讀5頁,還剩23頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、三級數(shù)據(jù)庫上機南開 100 題if(bibj) qw=bi; bi=bj; bj=qw;題目 1請編寫一個函數(shù) jsValue(int m,int k,int xx),該函數(shù)的功 能是:將大于整數(shù) m 且緊靠 m 的 k 個素數(shù)存入數(shù)組 xx 傳回。最后調(diào)用函數(shù) writeDat()讀取 10 組數(shù)據(jù),分別得出 結(jié)果且把結(jié)果輸出到文件 out.dat 中。部分源程序存在文件 prog1.c 中。例如:若輸入 17 5 則應(yīng)輸出:19,23,29,31,37。請勿改動主函數(shù) main()和寫函數(shù) writeDat()的內(nèi)容。int isP(int m)int i;for(i=2;i0;m+) i

2、f(isP(m) xxs+=m; k-;題目 2已知數(shù)據(jù)文件 IN.DAT 中存有 200 個四位數(shù),并已調(diào)用 讀函數(shù) readDat()把這些數(shù)存入數(shù)組 a 中,請考生編制一 函數(shù) jsVal(),其功能是:如果四位數(shù)各位上的數(shù)字均是0 或 2 或 4 或 6 或 8,則統(tǒng)計出滿足此條件的個數(shù) cnt, 并把這些四位數(shù)按從大到小的順序存入數(shù)組 b 中。最后 main( )函數(shù)調(diào)用寫函數(shù) writeDat()把結(jié)果 cnt 以及數(shù)組 b 中符合條件的四位數(shù)輸出到 OUT.DAT 文件中。void jsVal() int i,j,qw,bw,sw,gw;for(i=0;iMAX;i+) qw=a

3、i/1000; bw=ai/100%10;sw=ai%100/10; gw=ai%10;if(qw&qw%2=0&bw%2=0&sw%2=0&gw%2=0) bcnt+=ai;for(i=0;icnt-1;i+)for(j=i+1;jcnt;j+)*題目 3(字符型題)函數(shù) ReadDat( )實現(xiàn)從文件 IN.DAT 中讀取一篇英文文 章存入到字符串?dāng)?shù)組 xx 中;請編制函數(shù) StrOR( ),其函 數(shù)的功能是:以行為單位依次把字符串中所有小寫字母 o 左邊的字符串內(nèi)容移到該串的右邊存放,然后把小寫 字母 o 刪除,余下的字符串內(nèi)容移到已處理字符串的左 邊存放,之后把已處理的字符串仍按行重新

4、存入字符串 數(shù)組 xx 中。最后 main()函數(shù)調(diào)用函數(shù) WriteDat()把結(jié)果 xx 輸出到文件 OUT5.DAT 中void StrOR(void)int i,righto,j,s,k; char tem80; for(i=0;i=0;j-)k=0;memset(tem,0,80);if(xxij=o)righto=j;for(s=righto+1;sstrlen(xxi);s+)temk+=xxis; for(s=0;srighto;s+) if(xxis!=o) temk+=xxis; strcpy(xxi,tem);else continue;題目 4(字符處理發(fā)序輸出)函數(shù)

5、ReadDat()實現(xiàn)從文件 IN.DAT 中讀取一篇英文文章 存入到字符串?dāng)?shù)組 xx 中,請編制函數(shù) StrOL(),其函數(shù) 的功能是:以行為單位對行中以空格或標點符號為分隔 的所有單詞進行倒排。最后把已處理的字符串(應(yīng)不含 標點符號)仍按行重新存入字符串?dāng)?shù)組 xx 中,最后調(diào) 用函數(shù) writeDat()把結(jié)果 xx 輸出到文件 OUT6.DAT 中。例如:原文:You He MeI am a student.結(jié)果:Me He You student a am Ivoid StrOL(void)第 1 頁 共 28 頁 int i,j,k,s,m,strl; char str80; for

6、(i=0;i=0;j-) if(isalpha(xxij) k+;else for(m=1;m=k;m+)strs+=xxij+m;k=0;if(!isalpha(xxij)strs+= ;for(m=1;m=k;m+)strs+=xxij+m;strs=0;strcpy(xxi,str);題目 5(整數(shù)排序題)在文件 in.dat 中有 200 個正整數(shù),且每個數(shù)均在 1000 至9999 之間。函數(shù) ReadDat()讀取這 200 個數(shù)存放到數(shù)組 aa 中。請編制函數(shù) jsSort(),其函數(shù)的功能是:要求按每 個數(shù)的后三位的大小進行升序排列,然后取出滿足此條 件的前 10 個數(shù)依次存入

7、數(shù)組 bb 中,如果后三位的數(shù)值 相等,則按原先的數(shù)值進行降序排列。最后調(diào)用函數(shù) WriteDat()把結(jié)果 bb 輸出到文件 out.dat 中。例:處理前 60125099901270258088處理后 90126012702580885099void jsSort()int i,j,data; for(i=0;i199;i+) for(j=i+1;jaaj%1000|aai%1000=aaj%1000&aaiaaj)data=aai;aai=aaj;aaj=data;for(i=0;i10;i+)bbi=aai;9999 之間。函數(shù) ReadDat()讀取這 200 個數(shù)存放到數(shù)組 aa

8、 中。請編制函數(shù) jsSort(),其函數(shù)的功能是:要求按每 個數(shù)的后三位的大小進行降序排列,然后取出滿足此條 件的前 10 個數(shù)依次存入數(shù)組 b 中,如果后三位的數(shù)值 相等,則按原先的數(shù)值進行升序排列。最后調(diào)用函數(shù) WriteDat()把結(jié)果 bb 輸出到文件 out.dat 中。例:處理前 9012 5099 6012 7025 8088處理后 5099 8088 7025 6012 9012void jsSort()int i,j,data; for(i=0;i199;i+) for(j=i+1;j200;j+)if(aai%1000aaj)data=aai;aai=aaj;aaj=da

9、ta;for(i=0;i10;i+)bbi=aai;*題目 7(結(jié)構(gòu)體操作題)已知在文件 IN.DAT 中存有 100 個產(chǎn)品銷售記錄,每個 產(chǎn)品銷售記錄由產(chǎn)品代碼 dm( 字符型 4 位),產(chǎn)品名稱 mc(字符型 10 位),單價 dj(整型),數(shù)量 sl(整型),金額 je(長整型)五部分組成。其中:金額=單價*數(shù)量計算得出。 函數(shù) ReadDat()是讀取這 100 個銷售記錄并存入結(jié)構(gòu)數(shù) 組 sell 中。請編制函數(shù) SortDat(),其功能要求:按產(chǎn)品 代碼從大到小進行排列,若產(chǎn)品代碼相同,則按金額從 大到小進行排列,最終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組 sell 中, 最后調(diào)用函數(shù) Wri

10、teDat()把結(jié)果輸出到文件 OUT6.DAT 中。void SortDat()int i,j; PRO xy; for(i=0;i99;i+) for(j=i+1;j100;j+)*題目 6 正整數(shù)排序在文件 in.dat 中有 200 個正整數(shù),且每個數(shù)均在 1000 至if(strcmp(selli.dm,sellj.dm)0|strcmp(selli.dm,sellj.dm)=0&selli.jesellj.je)xy=selli; sell i=sellj; sellj=xy;第 2 頁 共 28 頁*題目 8(字符替換題)函數(shù) ReadDat()實現(xiàn)從文件 ENG.IN 中讀取一

11、篇英文文 章,存入到字符串?dāng)?shù)組 xx 中;請編制函數(shù) encryptChar(), 按給定的替代關(guān)系對數(shù)組 xx 中的所有字符進行替代, 仍存入數(shù)組 xx 的對應(yīng)的位置上,最后調(diào)用函數(shù) WriteDat() 把結(jié)果 xx 輸出到文件 PS1.DAT 中。替代關(guān)系:f(p)=p*11 mod 256(p 是數(shù)組中某一個 字符的 ASCII 值,f(p)是計算后新字符的 ASCII 值),如 果計算后 f(p)值小于等于 32 或大于 130,則該字符不變, 否則將 f(p)所對應(yīng)的字符進行替代。(注意中間變量用無 符號整型),部分源程序存在文件 prog1.c 中。原始數(shù)據(jù) 文件存放的格式是:每

12、行的寬度均小于 80 個字符。void encryptChar() int i,j;for(i=0;imaxline;i+)for(j=0;jstrlen(xxi);j+)if(xxij*11%256130)continue;else xxij=xxij*11%256;*題目 9(字符串排序題)函數(shù) ReadDat()實現(xiàn)從文件 IN.DAT 中讀取一篇英文文章 存入到字符串?dāng)?shù)組 xx 中,請編制函數(shù) SortCharD(),其 函數(shù)的功能是:以行為單位對字符按從大到小的順序進 行排序,排序后的結(jié)果仍按行重新存入字符串?dāng)?shù)組 xx 中,最后調(diào)用函數(shù) writeDat() 把結(jié)果 xx 輸出到文件

13、 OUT2.DAT 中。例:原文:dAe,BfC.CCbbAA 結(jié)果:fedCBA. bbCCAAvoid SortCharD(void)int i,j,k,strl; char ch; for(i=0;imaxline;i+)strl=strlen(xxi); for(j=0;jstrl-1;j+) for(k=j+1;kstrl;k+)if(xxijxxik)ch=xxij; xxij=xxik; xxik=ch;*題目 10(替換字符題)函數(shù) ReadDat()實現(xiàn)從文件 IN.DAT 中讀取一篇英文文章 存入到字符串?dāng)?shù)組 xx 中,請編制函數(shù) ConvertCharA(), 其函數(shù)的功

14、能是:以行為單位把字符串中的所有小寫字 母改寫成該字母的下一個字母,如果是字母 z,則改寫 成字母 a。大寫字母仍為大寫字母,小寫字母仍為小寫 字母,其他字符不變。把已處理的字符串仍按行重新存 入字符串?dāng)?shù)組 xx 中,最后調(diào)用函數(shù) writeDat()把結(jié)果 xx 輸出到文件 OUT1.DAT 中。例:原文:Adb.Bcdza abck.LLhj結(jié)果:Aec.Bdeab bcdl.LLikvoid ConvertCharA(void) int i,j;for(i=0;imaxline;i+) for(j=0;j=a&xxij=y)xxij+=1;*題目 11(字符串字母移位題)程序 prog1

15、.c 的功能是:把 s 字符串中的所有字母改寫 成該字母的下一個字母,字母 z 改寫成字母 a。要求大 寫字母仍為大寫字母,小寫字母仍為小寫字母,其它字 符不做改變。請考生編寫函數(shù) chg(char*s)實現(xiàn)程序要求,最后 調(diào)用函數(shù) readwriteDAT( )把結(jié)果輸出到文件 bc1.out 中。例如:s 字符串中原有的內(nèi)容為:Mn.123Zxy,則 調(diào)用該函數(shù)后,結(jié)果為:No.123Ayz。void chg(char *s)int I; for(I=0;I=a&si=A&si=Y)si+=1;第 3 頁 共 28 頁*題目 12(結(jié)構(gòu)體運算題題)已知在文件 IN.DAT 中存有 100

16、個產(chǎn)品銷售記錄,每個 產(chǎn)品銷售記錄由產(chǎn)品代碼 dm( 字符型 4 位),產(chǎn)品名稱 mc(字符型 10 位),單價 dj(整型),數(shù)量 sl(整型),金額 je(長整型)五部分組成。其中:金額=單價*數(shù)量計算得出。 函數(shù) ReadDat()是讀取這 100 個銷售記錄并存入結(jié)構(gòu)數(shù) 組 sell 中。請編制函數(shù) SortDat(),其功能要求: 按產(chǎn)品名稱從小到大進行排列,若產(chǎn)品名稱相等,則按 金額從小到大進行排列,最終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組 sell 中。void SortDat()int i,j; PRO xy; for(i=0;i99;i+) for(j=i+1;j0|strcmp(sell

17、i.mc,sellj. mc)=0&selli.jesellj.je)xy=selli;selli=sellj;sellj=xy;*題目 13(結(jié)構(gòu)體運算題)已知在文件 IN.DAT 中存有 100 個產(chǎn)品銷售記錄,每個 產(chǎn)品銷售記錄由產(chǎn)品代碼 dm( 字符型 4 位),產(chǎn)品名稱 mc(字符型 10 位),單價 dj(整型),數(shù)量 sl(整型),金額 je(長整型)五部分組成。其中:金額=單價*數(shù)量計算得出。 函數(shù) ReadDat()是讀取這 100 個銷售記錄并存入結(jié)構(gòu)數(shù) 組 sell 中。請編制函數(shù) SortDat(),其功能 要求:按產(chǎn)品代碼從小到大進行排列,若產(chǎn)品代碼相等, 則按金額從

18、大到小進行排列,最終排列結(jié)果仍存入結(jié)構(gòu) 數(shù)組 sell 中,最后調(diào)用函數(shù) WriteDat()把結(jié)果輸出到文 件 OUT9.DAT 中。void SortDat()int i,j; PRO xy; for(i=0;i99;i+) for(j=i+1;j0|strcmp(selli.dm,sellj.dm)=0&selli.jesellj.je)xy=selli;selli=sellj;sellj=xy;*題目 14(整數(shù)統(tǒng)計排序題)已知數(shù)據(jù)文件 IN.DAT 中存有 200 個四位數(shù),并已調(diào)用 讀函數(shù) readDat()把這些數(shù)存入數(shù)組 a 中,請考生編制一 函數(shù) jsVal(),其功能是:依

19、次從數(shù)組 a 中取出一個四位 數(shù),如果該四位數(shù)連續(xù)大于該四位數(shù)以后的五個數(shù)且該 數(shù)是奇數(shù)(該四位數(shù)以后不滿五個數(shù),則不統(tǒng)計),則 統(tǒng)計出滿足此條件的個數(shù) cnt 并把這些四位數(shù)按從小到 大的順序存入數(shù)組 b 中,最后調(diào)用寫函數(shù) writeDat( )把 結(jié) 果 cnt 以 及 數(shù) 組 b 中 符 合 條 件 的 四 位 數(shù) 輸 出 到 OUT.DAT 文件中。void jsVal()int i,j,flag;for(i=0;iMAX-5;i+)for(j=i+1;jaj&ai%2) flag=1; else flag=0;break;if(flag=1) bcnt+=ai;for(i=0;ic

20、nt-1;i+)for(j=i+1;jbj) flag=bi;bi=bj;bj=flag;*題目 15(整數(shù)各位數(shù)字運算排序題)已知數(shù)據(jù)文件 IN.DAT 中存有 200 個四位數(shù),并已調(diào)用 讀函數(shù) readDat()把這些數(shù)存入數(shù)組 a 中,請考生編制一 函數(shù) jsVal(),其功能是:若一個四位數(shù)的千位數(shù)字上的 值小于等于百位數(shù)字上的值,百位數(shù)字上的值小于等于 十位數(shù)字上的值,以及十位數(shù)字上的值小于等于個位數(shù) 字上的值,并且原四位數(shù)是偶數(shù),則統(tǒng)計出滿足此條件 的個數(shù) cnt 并把這些四位數(shù)按從小到大的順序存入數(shù)組b 中,最后調(diào)用寫函數(shù) writeDat()把結(jié)果 cnt 以及數(shù)組 b中符合

21、條件的四位數(shù)輸出到 OUT.DAT 文件中。void jsVal()int i,j;int qw,bw,sw,gw;for (i=0;iMAX;i+)qw=ai/1000;bw=ai%1000/100;sw=ai%100/10;gw=ai%10;第 4 頁 共 28 頁if(qw=bw)&(bw=sw)&(sw=gw)&(ai%2=0)bcnt+=ai;for(i=0;icnt-1;i+)for(j=i+1;jbj) qw=bi;bi=bj;bj=qw;*題目 16(字符替換題)函數(shù) ReadDat()實現(xiàn)從文件 IN.DAT 中讀取一篇英文文章 存入到字符串?dāng)?shù)組 xx 中,請編制函數(shù) Str

22、CharJR(),其 函數(shù)的功能是:以行為單位把字符串中所有字符 的 ASCII 值右移 4 位,然后把右移后的字符 ASCII 值再加 上原字符的 ASCII 值,得到新的字符仍存入原字符串對 應(yīng)的位置上。最后把已處理的字符串仍按行重新存入字 符串?dāng)?shù)組 xx 中,最后調(diào)用函數(shù) writeDat()把結(jié)果 xx 輸出 到文件 OUT8.DAT 中。void StrCharJR()int i,j;for(i=0;imaxline;i+)for(j=0;j4);(右移四位的表達方式)*題目 17 (親朋字符替換題)函數(shù) READDAT()實現(xiàn)從文件 IN.DAT 中讀取一篇英 文文章存入到字符串?dāng)?shù)

23、組 XX 中;請編制函數(shù) CHA(),其 函數(shù)功能是: 以行為單位把字符串中的第一個字符的 ASCII 值加第二個字符的 ASCII 值,得到第一個親朋字 符,第二個字符的 ASCII 值加第三個字符的 ASCII 值, 得到第二個新字符,依此類推一直處理到最后第二個字 符,最后一個字符的 ASCII 值加原第一個字符的 ASCII 值,得到最后一個新的字符,得到的新字符分別存放在 原字符串對應(yīng)的位置上。最后把已處理的字符串逆轉(zhuǎn)后 按 行 重 新 存 入 字 符 串 數(shù) 組 XX 中 , 最 后 調(diào) 用 函 數(shù) WRITEDAT()把結(jié)果 XX 輸出到文件 OUT9.DAT 中,原 始數(shù)據(jù)文件

24、存放的格式是:每行的寬度均小于 80 個字 符,含標點符號和空格。void ChA(void) int i,j; char ch; for(i=0;imaxline;i+) ch=xxi0;for(j=0;jstrlen(xxi)-1;j+)xxij+=xxij+1; xxistrlen(xxi)-1+=ch; strrev(xxi);*題目 18函數(shù) ReadDat()實現(xiàn)從文件 ENG.IN 中讀取一篇英文文 章,存入到字符串?dāng)?shù)組 xx 中;請編制函數(shù) encryptChar(), 按給定的替代關(guān)系對數(shù)組 xx 中的所有字符進行替代, 仍存入數(shù)組 xx 的對應(yīng)的位置上,最后調(diào)用函數(shù) Wri

25、teDat() 把結(jié)果 xx 輸出到文件 PS10.DAT 中。替代關(guān)系:f(p)=p*11 mod 256(p 是數(shù)組中某一個 字符的 ASCII 值,f(p)是計算后新字符的 ASCII 值),如 果原字符的 ASCII 值是偶數(shù)或計算后 f(p)值小于等于32,則該字符不變,否則將 f(p)所對應(yīng)的字符進行替代。void encryptChar() int i,j; for(i=0;imaxline;i+) for(j=0;jstrlen(xxi);j+)if(xxij*11%256=32|xxij%2=0) continue;else xxij=xxij*11%256;*題目 19(單

26、詞個數(shù)統(tǒng)計題)編寫一個函數(shù) findStr(char *str,char *substr),該函數(shù)統(tǒng)計 一個長度為 2 的子字符串在另一個字符串中出現(xiàn)的次 數(shù)。例如,假定輸入的字符串為asd asasdfg asd as zx67 asd mklo,子字符串為as,函數(shù)返回值是 6。(表明了 返回值是整數(shù)型)函數(shù) ReadWrite()實現(xiàn)從文件 in.dat 中讀取兩個字符 串,并調(diào)用函數(shù) findStr(),最后把結(jié)果輸出到文件 out.dat 中。int findStr(char *str,char *substr) int i,j,len1,len2,cnt=0,flag; len1=

27、strlen(str); len2=strlen(substr); for(i=0;ilen1;i+) for(j=0;jlen2;j+)if(stri+j=substrj)flag=1;第 5 頁 共 28 頁else flag=0;break;if(flag=1)cnt+;return cnt;*題目 20(Fibonacci 數(shù)列題)編寫函數(shù) jsValue,它的功能是:求 Fibonacci 數(shù)列中大 于 t 的最小的一個數(shù),結(jié)果由函數(shù)返回。其中 Fibonacci 數(shù)列 F(n)的定義為:F(0)=0,F(1)=1F(n)=F(n-1)+F(n-2)最后調(diào)用函數(shù) writeDat()

28、讀取 50 個數(shù)據(jù) t,分別得出 結(jié)果且把結(jié)果輸出到文件 out.dat 中。例如:當(dāng) t=1000 時,函數(shù)值為:1597。int jsValue(int t) int f0=0,f1=1,fn; fn=f0+f1; while(fn=0.000001);return x1;注:本題在無憂或捷成模擬盤中,需定義 double x0,x1; 才能通過,據(jù)實際上機抽到該題的考生反映,實際上機 需按上面解法的定義方能通過,特此說明,供參考。*題目 22(平方根問題)請編寫函數(shù) countValue(),它的功能是:求 n 以內(nèi)(不包 括 n)同時能被 3 與 7 整除的所有自然數(shù)之和的平方根 s,

29、并作為函數(shù)值返回,最后結(jié)果 s 輸出到文件 out.dat 中。例如若 n 為 1000 時,函數(shù)值應(yīng)為:s=153.909064。double countValue(int n) int i;double s=0.0;for(i=1;in;i+)if(i%21=0) s+=i;return sqrt(s);*題目 23 (實數(shù)運算題)已知在文件 in.dat 中存有 N 個(個數(shù)200)實數(shù),函數(shù) readdat()讀取這 N 個實數(shù)并存入數(shù)組 xx 中。請編制函數(shù) calvalue(),其功能要求:1、求出這 N 個實數(shù)的平均值 aver;2、分別求出這 N 個實數(shù)的整數(shù)部分之和 sumi

30、nt 以及小 數(shù)部分之和 sumdec,最后調(diào)用函數(shù) writedat()把所求的 結(jié)果輸出到文件 out.dat 中。注意:部分源程序已給出。void CalValue(void)int i;for (i=0;iN;i+)sumint+=(long)xxi; sumdec+=xxi-(long)xxi; aver+=xxi;aver/=N;第 6 頁 共 28 頁*題目 24(完全平方數(shù)問題)下列程序 prog1.c 的功能是:在三位整數(shù)(100 至 999) 中尋找符合條件的整數(shù)并依次從小到大存入數(shù)組中;它 既是完全平方數(shù),又是兩位數(shù)字相同,例如 144、676 等。請編制函數(shù)實現(xiàn)此功能,

31、滿足該條件的整數(shù)的個數(shù) 通過所編制的函數(shù)返回。或者下面的解法:int jsValue(long n)long int s=0,k;k=n;while(k) s=s*10+k%10;k/=10;if(s=n) return 1;if(s!=n) return 0;int jsValue(int bb)int i,j,k=0;int hun,ten,data;for(i=10;i32;i+)j=I*I; hum=j/100; ten=j%100/10; data=j%10;if(hum=ten|hum=data|ten=data)bbk+=j;return k;*題目 25 (回文數(shù)問題) 下列程

32、序的功能是:尋找并輸出 11 至 999 之間的數(shù) m, 它滿足 m,m2 和 m3 均為回文數(shù)。所謂回文數(shù)是指其各 位數(shù)字左右對稱的整數(shù),例如 121,676,94249 等。滿 足上述條件的數(shù)如 m=11,m2=121,m3=1331 皆為回文數(shù)。 請編制函數(shù) int svalue(long m)實現(xiàn)此功能,如果是回文 數(shù),則函數(shù)返回 1,反之則返回 0。最后把結(jié)果輸出到 文件 out.dat 中。int jsValue(long n)int i,strl,half;char xy20;ltoa(n,xy,10); /*注意這里不能使用 itoa()函數(shù),因為 n是 long 型的*/ s

33、trl=strlen(xy); half=strl/2; for(i=0;i=half) return 1;else return 0;輸出結(jié)果為:m=11,m*m=121,m*m*m=1331 m= 101,m*m= 10201,m*m*m= 1030301 m= 111,m*m= 12321,m*m*m= 1367631*題目 26(整數(shù)統(tǒng)計運算題)已知在文件 IN.DAT 中存有若干個(個數(shù)200)四位數(shù) 字的正整數(shù),函數(shù) ReadDat()讀取這若干個正整數(shù)并存入 數(shù)組 xx 中。請編制函數(shù) CalValue(),其功能要求:1、 求出這文件中共有多少個正整數(shù) totNum;2、求這些

34、數(shù) 右移 1 位后,產(chǎn)生的新數(shù)是偶數(shù)的數(shù)的個數(shù) totCnt,以 及滿足此條件的這些數(shù) ( 右移前的值 ) 的算術(shù)平均 值 totPjz,最后調(diào)用函數(shù) writeDat()把所求的結(jié)果輸出到文 件 OUT.DAT 中。void CalValue(void)int i,data;for(i=0;i0) totNum+; data=xxi1; if(data%2=0)totCnt+;totPjz+=xxi;if(totCnt=0) totPjz=0;else totPjz/=totCnt;*題目 27(整數(shù)各位數(shù)字運算題)已知數(shù)據(jù)文件 in.dat 中存有 300 個四位數(shù),并已調(diào)用讀 函數(shù) Re

35、adDat()把這些數(shù)存入數(shù)組 a 中,請編制一函數(shù) jsValue(),其功能是:求出千位數(shù)上的數(shù)減百位數(shù)上的 數(shù)減十位數(shù)上的數(shù)減個位數(shù)上的數(shù)大于零的個數(shù) cnt, 再把所有滿足此條件的四位數(shù)依次存入數(shù)組 b 中,然后第 7 頁 共 28 頁對數(shù)組 b 的四位數(shù)按從小到大的順序進行排序,最后調(diào) 用寫函數(shù) writeDat()把結(jié)果輸出到 out.dat 文件。例如:9123,9-1-2-30,則該數(shù)滿足條件存入數(shù)組b 中,且個數(shù) cnt=cnt+1。9812,9-8-1-20,則該數(shù)不滿足條件忽略。jsValue() int i,j,qw,bw,sw,gw;for(i=0;i0) bcnt+

36、=ai;for(i=0;icnt-1;i+)for(j=i+1;jbj) qw=bi; bi=bj; bj=qw;*題目 28(整數(shù)各位打散組合運算題)已知數(shù)據(jù)文件 IN.DAT 中存有 200 個四位數(shù),并已調(diào)用 讀函數(shù) readDat()把這些數(shù)存入數(shù)組 a 中,請考生編制一 函數(shù) jsVal(),其功能是:把千位數(shù)字和十位數(shù)字重新組 成一個新的十位數(shù) ab(新十位數(shù)的十位數(shù)字是原四位數(shù) 的千位數(shù)字,新十位數(shù)的個位數(shù)字是原四位數(shù)的十位數(shù) 字),以及把個位數(shù)字和百位數(shù)字組成另一個新的十位 數(shù) cd(新十位數(shù)的十位數(shù)字是原四位數(shù)的個位數(shù)字,新 十位數(shù)的個位數(shù)字是原四位數(shù)的百位數(shù)字),如果新組

37、成的兩個十位數(shù) ab-cd=0 且 ab-cd=10 且兩個數(shù)均是奇 數(shù),同時兩個新數(shù)的十位數(shù)字均不為零,則將滿足此條 件的四位數(shù)按從大到小的順序存入數(shù)組 b 中,并要計算 滿足上述條件的四位數(shù)的個數(shù) cnt。最后 main()函數(shù)調(diào)用 寫函數(shù) writeDat( )把結(jié)果 cnt 以及數(shù)組 b 中符合條件的四 位數(shù)輸出到 OUT.DAT 文件中。void jsVal()int i,j,thou,hun,ten,data,ab,cd;for(i=0;i=0&(ab-cd)=10&cd=10)bcnt+=ai;for(i=0;icnt-1;i+)for(j=i+1;jcnt;j+)if(bi=1

38、0 且 ab-cd=20 且兩個數(shù)均是 偶數(shù),同時兩個新數(shù)的十位數(shù)字均不為零,則將滿足此 條件的四位數(shù)按從大到小的順序存入數(shù)組 b 中,并要計 算滿足上述條件的四位數(shù)的個數(shù) cnt。void jsVal() int i,j,qw,bw,sw,gw,ab,cd;for(i=0;i=10&ab-cd=20&ab%2=0&cd%2=0&qw!=0&gw!=0)bcnt+=ai;for(i=0;icnt-1;i+)for(j=i+1;jcnt;j+)if(bibj) qw=bi;bi=bj;bj=qw;*題目 30(整數(shù)統(tǒng)計排序題)已知數(shù)據(jù)文件 IN.DAT 中存有 200 個四位數(shù),并已調(diào)用 讀函數(shù)

39、 readDat()把這些數(shù)存入數(shù)組 a 中,請考生編制一 函數(shù) jsVal(),其功能是:依次從數(shù)組 a 中取出一個四位 數(shù),如果該四位數(shù)連續(xù)小于該四位數(shù)以后的五個數(shù)且該 數(shù)是偶數(shù)(該四位數(shù)以后不滿五個數(shù),則不統(tǒng)計),則 統(tǒng)計出滿足此條件的個數(shù) cnt 并把這些四位數(shù)按從小到 大的順序存入數(shù)組 b 中,最后調(diào)用寫函數(shù) writeDat( )把 結(jié) 果 cnt 以 及 數(shù) 組 b 中 符 合 條 件 的 四 位 數(shù) 輸 出 到 OUT.DAT 文件中。void jsVal()第 8 頁 共 28 頁int i,j,flag;for(i=0;iMAX-5;i+)for(j=i+1;j=i+5;j

40、+) if(aiaj&ai%2=0) flag=1; else flag=0; break;if(flag=1) bcnt+=ai;for(i=0;icnt-1;i+)for(j=i+1;jbj) flag=bi;bi=bj;bj=flag;*題目 31(結(jié)構(gòu)體運算題)已知在文件 IN.DAT 中存有 100 個產(chǎn)品銷售記錄,每個 產(chǎn)品銷售記錄由產(chǎn)品代碼 dm( 字符型 4 位),產(chǎn)品名稱 mc(字符型 10 位),單價 dj(整型),數(shù)量 sl(整型),金額 je(長整型)五部分組成。其中:金額=單價*數(shù)量計算得出。 函數(shù) ReadDat()是讀取這 100 個銷售記錄并存入結(jié)構(gòu)數(shù) 組 se

41、ll 中。請編制函數(shù) SortDat(),其功能要求:按金額 從大到小進行排列,若金額相同,則按產(chǎn)品代碼從大到 小進行排列, 最終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組 sell 中,最 后調(diào)用函數(shù) WriteDat() 把結(jié)果輸出到文件 OUT4.DAT 中。void SortDat()int i,j; PRO xy; for(i=0;i99;i+) for(j=i+1;j100;j+)if(selli.jesellj.je|selli.je=sellj.je&strcmp(selli. dm,sellj.dm)0)xy=selli;selli=sellj;sellj=xy;中。void SortDat()int i,j; PRO xy; for(i=0;i99;i+) for(j=i+1;j100;j+)if(strcmp(

溫馨提示

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

評論

0/150

提交評論