C语言(CED)如何用sort函数根据结构体里的某一属性进行排序
生活随笔
收集整理的這篇文章主要介紹了
C语言(CED)如何用sort函数根据结构体里的某一属性进行排序
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
(請先看置頂博文)https://blog.csdn.net/GenuineMonster/article/details/104495419? ? ? ?
前幾天在編寫代碼的時候,突然要根據(jù)結(jié)構(gòu)體的屬性進(jìn)行從小到大的排序,這即是我寫這篇文章的導(dǎo)火索。
正如大家所知道的那樣,我們在排序時通常會進(jìn)行sort(a,a+n):a為數(shù)組名稱,n為數(shù)組長度。這樣來的快捷方便,但是,在我看來,要適當(dāng)?shù)膶ε判蛩惴ㄟM(jìn)行復(fù)習(xí)。
? ? ? ? 那么如何根據(jù)結(jié)構(gòu)體的某一屬性進(jìn)行排序呢?請看下面這段代碼:
struct home {int s;//定義起點int e;//定義終點int num;//定義長度int p=0;//做一個標(biāo)記 };若在整個程序中,想根據(jù)home結(jié)構(gòu)體的e屬性,即終點進(jìn)行從小到大排序,則可以使用bool函數(shù)進(jìn)行配合,例如:
bool cmp(home f,home d) {return f.e < d.e;//選擇起點從小到大排序 }在bool函數(shù)中,“<”代表依據(jù)某一個值,從小到大進(jìn)行排序。具體在排序函數(shù)中應(yīng)該這樣進(jìn)行:
sort(a, a + n, cmp);//根據(jù)末尾節(jié)點,對種樹區(qū)間進(jìn)行排序由此達(dá)到依據(jù)結(jié)構(gòu)體中某一特定屬性進(jìn)行排序的目的。
PS:如果僅想對數(shù)組下表1以后的元素進(jìn)行排序,則可以這樣調(diào)用函數(shù)sort(a+1,n,cmp)
?
?
?
總結(jié)
以上是生活随笔為你收集整理的C语言(CED)如何用sort函数根据结构体里的某一属性进行排序的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: C语言(CED)与long long相关
- 下一篇: HashMap 源码阅读