40.已知在文件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(),其功能要求:按產(chǎn)品名稱從大到小進(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<99; i++)
for (j=i+1; j<100; j++)
if (strcmp(sell[i].name, sell[j].name) < 0)
{ temp = sell[i];
sell[i] = sell[j];
sell[j] = temp;
}
else if (strcmp(sell[i].name, sell[j].name) == 0)
{ if (sell[i].sum < sell[j].sum)
{ temp = sell[i];
sell[i] = sell[j];
sell[j] = temp;
}
}
}
41.
函數(shù)RData()實(shí)現(xiàn)從文件IN.dat中讀取20行數(shù)據(jù)存放到字符串?dāng)?shù)組str中(每行字符串長(zhǎng)度均小于80)。請(qǐng)編寫函數(shù)oddSort(),其功能是:以行為單位對(duì)字符串變量的下標(biāo)為奇數(shù)的字符按其ASCII值從小到大的順序進(jìn)行排序,排序后的結(jié)果仍按行重新存入字符串?dāng)?shù)組str中。最后調(diào)用函數(shù)WData(),把結(jié)果str輸出到OUT.dat文件中。
例如,位置 0 1 2 3 4 5 6 7
源字符串 h g f e d c b a
則處理后字符串 h a f c d e b g
【答案】
void oddSort()
{ int i, j, k, strl;
char ch;
for (i=0; i<20; i++)
{ strl = strlen(str[i]);
for (j=1; j for (k=j+2; k if (str[i][j] > str[i][k]) { ch = str[i][j]; str[i][j] = str[i][k]; str[i][k] = ch; } } } 42.已知數(shù)據(jù)文件IN.dat中存有200個(gè)四位數(shù),并已調(diào)用讀函數(shù)RData()把這些數(shù)存入數(shù)組a中,請(qǐng)編寫函數(shù)evenVal(),其功能是:依次從數(shù)組a中取出一個(gè)四位數(shù),如果該四位數(shù)連續(xù)大于該四位數(shù)以前的5個(gè)數(shù)且該數(shù)是偶數(shù)(該四位數(shù)以前不滿5個(gè)數(shù),則不統(tǒng)計(jì)),則統(tǒng)計(jì)出滿足此條件的個(gè)數(shù)count并把這些四位數(shù)按從大到小的順序存入數(shù)組b中。最后調(diào)用寫函數(shù)WData(),把結(jié)果count以及數(shù)組b中符合條件的四位數(shù)輸出到OUT.dat文件中。 【答案】 void evenVal() { int i, j, flag = 0; for (i=5; i { for (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; } } 2011計(jì)算機(jī)等級(jí)三級(jí)數(shù)據(jù)庫(kù)考前實(shí)訓(xùn)練習(xí)匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |