【考點分析】 本題考查對結(jié)構(gòu)體數(shù)組的排序,可以用起泡法來實現(xiàn)。考查的知識點包括:結(jié)構(gòu)體成員運算,字符串比較符,數(shù)組排序。
【解題思路】 此題屬于銷售記錄類題型;此類題型主要考查對結(jié)構(gòu)體數(shù)組的排序。解題時,應注意3個關(guān)鍵點:關(guān)鍵點1本題為按產(chǎn)品代碼從小到大排序;關(guān)鍵點2本題為如果產(chǎn)品代碼相同;關(guān)鍵點3本題為按金額從小到大排列。
本題在每次記錄比較時,首先用字符串比較函數(shù)strcmp比較兩個產(chǎn)品的代碼,如果返回的值大于0,則這兩個產(chǎn)品進行數(shù)據(jù)交換;如果返回值等于0,再比較兩個產(chǎn)品的金額,如果前一個產(chǎn)品的金額大于后一個產(chǎn)品的金額,則這兩個產(chǎn)品進行數(shù)據(jù)交換。
【參考答案】
void SortDat()
{
int i,j; /*定義循環(huán)控制變量*/
PRO temp; /*定義數(shù)據(jù)交換時的暫存變量(這里是PRO類型的結(jié)構(gòu)體變量)*/
for(i=0;i<99;i++) /*利用選擇法進行排序*/
for(j=i+1;j<100;j++)
if (strcmp(sell[i].dm,sell[j].dm)>0) /*按產(chǎn)品代碼從小到大進行排列*/
{
temp=sell[i];
sell [i]=sell[j];
sell[j]=temp;
}
else if(strcmp(sell[i].dm,sell[j].dm)==0) /*若產(chǎn)品代碼相同,則按金額從小到大進行排列*/
if(sell[i].je>sell[j].je)
{
temp=sell[i];
sell[i]=sell[j];
sell[j]=temp;
}
}
【易錯提示】 結(jié)構(gòu)型數(shù)據(jù)對成員的訪問用"."成員運算符;兩個字符串的比較用字符串比較函數(shù)strcmp();if結(jié)構(gòu)中的邏輯表達式。
相關(guān)推薦:
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |