文章責編:lipeng566
看了本文的網友還看了學歷| 高考 中考 考研 自考 成考 外語| 四六級 職稱英語 商務英語 公共英語 資格| 公務員 報關員 銀行 證券 司法 導游 教師 計算機| 等考 軟考
工程|一建 二建 造價師 監(jiān)理師 咨詢師 安全師 結構師 估價師 造價員 會計| 會計證 會計職稱 注會 經濟師 稅務師 醫(yī)學| 衛(wèi)生資格 醫(yī)師 藥師 [更多]
【解題思路】 此題屬于銷售記錄類題型;此類題型主要考查對結構體數組的排序。解題時,應注意3個關鍵點:關鍵點1本題為按產品金額從小到大排序;關鍵點2本題為如果產品金額相同;關鍵點3本題為按產品代碼從大到小排列。
本題在每次記錄比較時,首先比較兩個產品的金額,如果前一個產品的金額大于后一個產品的金額,則這兩個產品進行數據交換;若產品的金額相等,則用字符串比較函數strcmp比較兩個產品的代碼,如果返回的值小于0,則這兩個產品進行數據交換。
【參考答案】
void SortDat()
{
int i,j; /*定義循環(huán)控制變量*/
PRO temp; /*定義數據交換時的暫存變量(這里是PRO類型的結構體變量)*/
for(i=0;i<99;i++) /*利用選擇法進行排序*/
for(j=i+1;j<100;j++)
if (sell[i].je>sell[j].je) /*按金額從小到大進行排列*/
{
temp=sell[i];
sell[i]=sell[j];
sell[j]=temp;
}
else if (sell[i].je==sell[j].je) /*若金額相同*/
if (strcmp(sell[i].dm,sell[j].dm)<0) /*則按產品代碼從大到小進行排列*/
{
temp=sell[i];
sell[i]=sell[j];
sell[j]=temp;
}
}
相關推薦:
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |