52.在文件IN.dat中有200組數(shù)據(jù),每組有3個(gè)數(shù),每個(gè)數(shù)均是三位數(shù)。函數(shù)Rdata()讀取這200組數(shù)據(jù)存放到結(jié)構(gòu)數(shù)組aa中,請(qǐng)編寫(xiě)函數(shù)numSort(),其功能是:要求在200組數(shù)據(jù)中找出條件為每組中的第2個(gè)數(shù)大于第1個(gè)數(shù)加第3個(gè)數(shù)之和,其中滿(mǎn)足條件的組數(shù)作為函數(shù)numSort()的返回值,同時(shí)把滿(mǎn)足條件的數(shù)據(jù)存入結(jié)構(gòu)數(shù)組bb中,再對(duì)bb中的數(shù)據(jù)按照每組數(shù)據(jù)的第2個(gè)數(shù)加第3個(gè)數(shù)之和的大小進(jìn)行降序排列(第2個(gè)數(shù)加第3個(gè)數(shù)的和均不相等),排序后的結(jié)果仍重新存入結(jié)構(gòu)數(shù)組bb中。最后調(diào)用函數(shù)Wdata(),把結(jié)果bb輸出到文件OUT.dat中。
【答案】
int numSort()
{ int i, cnt = 0, j;
data ch;
for (i=0; i<200; i++)
if (aa[i].x2 > aa[i].x1+aa[i].x3)
{ bb[cnt] = aa[i];
cnt++;
}
for (i=0; i for (j=i+1; j if (bb[i].x2+bb[i].x3 < bb[j].x2+bb[j].x3) { ch = bb[i]; bb[i] = bb[j]; bb[j] = ch; } return cnt; } 53.已知數(shù)據(jù)文件IN.dat中存有200個(gè)四位數(shù),并已調(diào)用讀函數(shù)rData()把這些數(shù)存入數(shù)組a中,請(qǐng)編寫(xiě)函數(shù)CalVal(),其功能是:把一個(gè)四位數(shù)的千位數(shù)字上的值加上十位數(shù)字上的值恰好等于百位數(shù)字上的值加上個(gè)位數(shù)字上的值,并且原四位數(shù)是偶數(shù),則統(tǒng)計(jì)出滿(mǎn)足此條件的四位數(shù)的個(gè)數(shù)count,并把這些四位數(shù)按從小到大的順序存入數(shù)組b中。最后調(diào)用寫(xiě)函數(shù)wData(),把結(jié)果count以及數(shù)組b中符合條件的四位數(shù)輸出到OUT.dat文件中。 【答案】 void CalVal() { int i, thou, hun, ten, data, j; for (i=0; i { thou = a[i]/1000; hun = a[i]%1000/100; ten = a[i]%100/10; data = a[i]%10; if ((thou+ten==hun+data) && a[i]%2!=1) { 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; } } 54.已知在文件IN.dat中存有100個(gè)產(chǎn)品銷(xiāo)售記錄,每個(gè)產(chǎn)品銷(xiāo)售記錄由產(chǎn)品代碼code(字符型4位)、產(chǎn)品名稱(chēng)name(字符型10位)、單價(jià)uprice(整型)、數(shù)量amount(整型)、金額sum(長(zhǎng)整型)5部分組成。其中:金額=單價(jià)×數(shù)量。函數(shù)ReadDat()是讀取這100個(gè)銷(xiāo)售記錄并存入結(jié)構(gòu)數(shù)組sell中。請(qǐng)編寫(xiě)函數(shù)SortDat(),其功能要求:按金額從小到大進(jìn)行排列,若金額相同,則按產(chǎn)品代碼從大到小進(jìn)行排列,最終排列結(jié)果仍存入結(jié)構(gòu)數(shù)組sell中。最后調(diào)用函數(shù)WriteDat(),把結(jié)果輸出到OUT.dat文件中。 注 【答案】 void SortDat() { int i, j; PRO temp; for (i=0; i<99; i++) for (j=i+1; j<100; 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; } } } 2011計(jì)算機(jī)等級(jí)三級(jí)數(shù)據(jù)庫(kù)考前實(shí)訓(xùn)練習(xí)匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |