43.已知在文件IN.dat中存有100個產品銷售記錄,每個產品銷售記錄由產品代碼code(字符型4位)、產品名稱name(字符型10位)、單價uprice(整型)、數量amount(整型)、金額sum(長整型)5部分組成。其中:金額=單價×數量。函數RData()讀取這100個銷售記錄并存入結構數組sell中。請編寫函數SortDat(),其功能是:按金額從大到小進行排列,若金額相等,則按產品代碼從小到大進行排列,最終排列結果仍存入結構數組sell中。最后調用函數WData(),把結果輸出到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.函數Rdata()實現從文件IN.dat中讀取一篇英文文章,存入字符串數組str中。請編寫函數encryptChar(),其功能是:按給定的替代關系對數組str中的所有字符進行替代后,仍存入數組str的對應位置上。最后調用函數Wdata(),把結果str輸出到OUT.dat文件中。 替代關系:f(p)=p*11mod 256(p是數組中某一個字符的ASCII值,f(p)是計算后新字符的ASCII值),如果計算后f(p)值小于等于32或f(p)對應的字符是小寫字母,則該字符不變,否則將f(p)所對應的字符進行替代。 原始數據文件存放的格式是:每行的寬度均小于80個字符。 【答案】 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.已知數據文件IN.dat中存有300個四位數,并已調用讀函數RData()把這些數存入數組a中,請編寫函數spellVal(),其功能是:求出千位上的數加個位上的數等于百位上的數加十位上的數的個數count,再把所有滿足此條件的四位數依次存入數組b中,然后對數組b的四位數按從小到大的順序進行排序。最后調用寫函數WData(),把結果輸出到OUT.dat文件中。 例如,6712,6+2=7+1,則該數滿足條件存入數組b中,且個數count=count+1。8129,8+9!=1+2,則該數不滿足條件,不存入數組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; } }
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |