43.已知在文件IN.dat中存有100個(gè)產(chǎn)品銷售記錄,每個(gè)產(chǎn)品銷售記錄由產(chǎn)品代碼code(字符型4位)、產(chǎn)品名稱name(字符型10位)、單價(jià)uprice(整型)、數(shù)量amount(整型)、金額sum(長(zhǎng)整型)5部分組成。其中:金額=單價(jià)×數(shù)量。函數(shù)RData()讀取這100個(gè)銷售記錄并存入結(jié)構(gòu)數(shù)組sell中。請(qǐng)編寫函數(shù)SortDat(),其功能是:按金額從大到小進(jìn)行排列,若金額相等,則按產(chǎn)品代碼從小到大進(jìn)行排列,最終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組sell中。最后調(diào)用函數(shù)WData(),把結(jié)果輸出到OUT.dat文件中。
【答案】
void SortDat()
{ int i, j;
PRO temp;
for (i=0; i for (j=i+1; j if (sell[i].sum < sell[j].sum) { temp = sell[i]; sell[i] = sell[j]; sell[j] = temp; } else if (sell[i].sum == sell[j].sum) { if (strcmp(sell[i].code, sell[j].code) > 0) { temp = sell[i]; sell[i] = sell[j]; sell[j] = temp; } } } 44.函數(shù)Rdata()實(shí)現(xiàn)從文件IN.dat中讀取一篇英文文章,存入字符串?dāng)?shù)組str中。請(qǐng)編寫函數(shù)encryptChar(),其功能是:按給定的替代關(guān)系對(duì)數(shù)組str中的所有字符進(jìn)行替代后,仍存入數(shù)組str的對(duì)應(yīng)位置上。最后調(diào)用函數(shù)Wdata(),把結(jié)果str輸出到OUT.dat文件中。 替代關(guān)系:f(p)=p*11mod 256(p是數(shù)組中某一個(gè)字符的ASCII值,f(p)是計(jì)算后新字符的ASCII值),如果計(jì)算后f(p)值小于等于32或f(p)對(duì)應(yīng)的字符是小寫字母,則該字符不變,否則將f(p)所對(duì)應(yīng)的字符進(jìn)行替代。 原始數(shù)據(jù)文件存放的格式是:每行的寬度均小于80個(gè)字符。 【答案】 void encryptChar() { int i; char *pf; for (i=0; i { pf = str[i]; while (*pf != 0) { if ((*pf*11%256>='a' && *pf*11%256<='z') || *pf*11%256<=32) { pf++; continue; } *pf = *pf*11%256; pf++; } } } 45.已知數(shù)據(jù)文件IN.dat中存有300個(gè)四位數(shù),并已調(diào)用讀函數(shù)RData()把這些數(shù)存入數(shù)組a中,請(qǐng)編寫函數(shù)spellVal(),其功能是:求出千位上的數(shù)加個(gè)位上的數(shù)等于百位上的數(shù)加十位上的數(shù)的個(gè)數(shù)count,再把所有滿足此條件的四位數(shù)依次存入數(shù)組b中,然后對(duì)數(shù)組b的四位數(shù)按從小到大的順序進(jìn)行排序。最后調(diào)用寫函數(shù)WData(),把結(jié)果輸出到OUT.dat文件中。 例如,6712,6+2=7+1,則該數(shù)滿足條件存入數(shù)組b中,且個(gè)數(shù)count=count+1。8129,8+9!=1+2,則該數(shù)不滿足條件,不存入數(shù)組b中,count變量也不加1。 【答案】 void spellVal() { int i, thou, hun, ten, data, j; for (i=0; i<300; i++) { thou = a[i]/1000; hun = a[i]%1000/100; ten = a[i]%100/10; data = a[i]%10; if (thou+data == hun+ten) { b[count] = a[i]; count++; } } for (i=0; i for (j=i+1; j if (b[i] > b[j]) { data = b[i]; b[i] = b[j]; b[j] = data; } } 2011計(jì)算機(jī)等級(jí)三級(jí)數(shù)據(jù)庫考前實(shí)訓(xùn)練習(xí)匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |