79.下列程序的功能是:利用"Xn+1=cos(Xn)"迭代方法求方程:cos(X)-X=0的一個(gè)實(shí)根。
迭代步驟為:①取X1初值為0.0;②X0=X1,把X1的值賦給X0;③X1=cos(X0),求出一個(gè)新的X1;④若X0-X1的絕對(duì)值小于0.000001,執(zhí)行步驟⑤,否則執(zhí)行步驟②;⑤所求X1就是方程cos(X)-X=0的一個(gè)實(shí)根,作為函數(shù)值返回。
請(qǐng)編寫函數(shù)countValue()實(shí)現(xiàn)程序的要求,最后調(diào)用函數(shù)WData(),把結(jié)果輸出到文件OUT.dat中。
【答案】
float countValue()
{ float X0, X1 = 0.0;
while (1)
{ X0 = X1;
X1 = (float)cos(X0);
if (fabs(X0-X1) < 1e-6)
break;
}
return X1;
}
80.函數(shù)Rdata()實(shí)現(xiàn)從文件IN.dat中讀取一篇英文文章,存入到字符串?dāng)?shù)組string中;請(qǐng)編寫encryptChar()函數(shù),其功能是:按給定的替代關(guān)系對(duì)數(shù)組string中的所有字符進(jìn)行替代后,仍存入數(shù)組string的對(duì)應(yīng)位置上。最后調(diào)用函數(shù)Wdata(),把結(jié)果string輸出到文件OUT.dat中。
替代關(guān)系:f(p)=p*11 mod 256(p是數(shù)組中某一個(gè)字符的ASCII值,f(p)是計(jì)算后新字符的ASCII值),如果計(jì)算后f(p)值小于等于32或其ASCII值是奇數(shù),則該字符不變,否則將f(p)所對(duì)應(yīng)的字符進(jìn)行替代。
原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個(gè)字符。
【答案】
void encryptChar()
{ int i;
char *pf;
for (i=0; i { pf = string[i]; while (*pf != 0) { if (((*pf*11 % 256)%2 != 0) || *pf*11 % 256<=32) { pf++; continue; } *pf = *pf*11%256; pf++; } } } 81.現(xiàn)有一個(gè)10個(gè)人的100行選票數(shù)據(jù)文件IN.dat,其數(shù)據(jù)存放的格式是每條記錄的長(zhǎng)度均為10位,第一位表示第1個(gè)人的選中情況,第二位表示第2個(gè)人的選中情況,以此類推;內(nèi)容均為字符0或1,1表示此人被選中,0表示此人未被選中,全選或全不選均為無(wú)效的選票。給定函數(shù)RData()的功能是把選票數(shù)據(jù)讀入字符串?dāng)?shù)組original中。請(qǐng)編寫函數(shù)CountRs()來(lái)統(tǒng)計(jì)每個(gè)人的選票數(shù)并把得票數(shù)依次存入result[0]到result[9]中,把結(jié)果result輸出到OUT.dat文件中。 【答案】 void CountRs(void) { int i, j = 0, k; char *str; for (i=0; i<10; i++) result[i] = 0; for (i=0; i<100; i++) { str = original[i]; j = 0; while (*str) { if (*str == '1') j++; str++; } if (j!=0 && j!=10) for (k=0; k<10; k++) result[k] += original[i][k]-'0'; } }
2011計(jì)算機(jī)等級(jí)三級(jí)數(shù)據(jù)庫(kù)考前實(shí)訓(xùn)練習(xí)匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |