28.已知在文件IN.dat中存有若干個(<200)四位數(shù)字的正整數(shù),函數(shù)RData()讀取這若干個正整數(shù)并存入數(shù)組original中。請編寫函數(shù)CalValue(),其功能要求是:①求出這個文件中共有多少個正整數(shù)totNum;②求這些數(shù)右移1位后,產(chǎn)生的新數(shù)是偶數(shù)的數(shù)的個數(shù)toteven,以及滿足此條件的這些數(shù)(右移前的值)的算術(shù)平均值totavg。最后調(diào)用函數(shù)WData()把所求的結(jié)果輸出到OUT.dat文件中。
【答案】
void CalValue(void)
{ int i, data;
for (i=0; i { if (!original[i]) break; if (original[i] > 0) totNum++; data = original[i]>>1; if (data%2 == 0) { toteven++; totavg += original[i]; } } totavg /= toteven; } 29.已知數(shù)據(jù)文件IN.dat中存有200個四位數(shù),并已調(diào)用讀函數(shù)RData()把這些數(shù)存入數(shù)組a中,請編寫函數(shù)spellVal(),其功能是:把千位數(shù)字和十位數(shù)字重新組成一個新的二位數(shù)ab(新二位數(shù)的十位數(shù)字是原四位數(shù)的千位數(shù)字,新二位數(shù)的個位數(shù)字是原四位數(shù)的十位數(shù)字),以及把個位數(shù)字和百位數(shù)字組成另一個新的二位數(shù)cd(新二位數(shù)的十位數(shù)字是原四位數(shù)的個位數(shù)字,新二位數(shù)的個位數(shù)字是原四位數(shù)的百位數(shù)字),如果新組成的兩個二位數(shù)ab-cd≥0且ab-cd≤10且兩個數(shù)均是奇數(shù),同時兩個新數(shù)的十位數(shù)字均不為0,則將滿足此條件的四位數(shù)按從大到小的順序存入數(shù)組b中,并要計算滿足上述條件的四位數(shù)的個數(shù)count。最后main()函數(shù)調(diào)用寫函數(shù)WData(),把結(jié)果count以及數(shù)組b中符合條件的四位數(shù)輸出到OUT.dat文件中。 【答案】 void spellVal() { int i, thou, hun, ten, data, j; int ab, cd; for (i=0; i<200; i++) { thou = a[i]/1000; hun = a[i]%1000/100; ten = a[i]%100/10; data = a[i]%10; if (thou==0 || data==0) continue; ab = 10*thou+ten; cd = 10*data+hun; if ((ab-cd)>=0 && (ab-cd)<=10 && ab%2==1 && cd%2==1) { b[cnt] = a[i]; cnt++; } } for (i=0; i for (j=i+1; j if (b[i] < b[j]) { data = b[i]; b[i] = b[j]; b[j] = data; } } 已知數(shù)據(jù)文件IN.dat中存有200個四位數(shù),并已調(diào)用讀函數(shù)RData()把這些數(shù)存入數(shù)組a中,請編寫函數(shù)seVal(),其功能是:依次從數(shù)組a中取出一個四位數(shù),如果該四位數(shù)連續(xù)小于該四位數(shù)以后的5個數(shù)且該數(shù)是偶數(shù)(該四位數(shù)以后不滿4個數(shù),則不統(tǒng)計),則統(tǒng)計出滿足此條件的個數(shù)count并把這些四位數(shù)按從小到大的順序存入數(shù)組b中。最后調(diào)用寫函數(shù)WData(),把結(jié)果count以及數(shù)組b中符合條件的四位數(shù)輸出到OUT.dat文件中。 注意:部分程序已經(jīng)給出。程序中已定義數(shù)組a[200]、b[200],已定義變量count。請勿改動數(shù)據(jù)文件 【答案】 void seVal() { int i, j, flag = 0; for (i=0; i { for (j=i+1; j<=i+5; j++) if (a[i] < a[j]) { flag = 1; } else { flag = 0; break; } if (flag==1 && a[i]%2==0) { b[count] = a[i]; count++; } } for (i=0; i for (j=i+1; j if (b[i] > b[j]) { flag = b[i]; b[i] = b[j]; b[j] = flag; } }
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |