3 回答

TA貢獻(xiàn)1805條經(jīng)驗(yàn) 獲得超9個(gè)贊
std::sort需要其滿足分揀機(jī)嚴(yán)格弱排序規(guī)則,這是解釋 在這里
因此,您的比較器說,a < b當(dāng)a == b不遵循嚴(yán)格的弱排序規(guī)則時(shí),該算法可能會(huì)崩潰,因?yàn)樗鼘⑦M(jìn)入無限循環(huán)。

TA貢獻(xiàn)2039條經(jīng)驗(yàn) 獲得超8個(gè)贊
xorguy的答案非常好。
我只是從標(biāo)準(zhǔn)中添加一些報(bào)價(jià):
25.4排序及相關(guān)操作[alg.sorting]
為了使25.4.3中描述的算法無法正常工作,comp必須在值上引入嚴(yán)格的弱排序。
術(shù)語“ 嚴(yán)格”是指對(duì)非自反關(guān)系的要求(!comp(x,x)對(duì)于所有x),而術(shù)語“ 弱于”的要求不如總訂購的要求強(qiáng),但要強(qiáng)于部分訂購的要求。 。
所以xorguy很好地解釋了這一點(diǎn):您的comp函數(shù)說,a < b當(dāng)a == b哪個(gè)不遵循嚴(yán)格的弱排序規(guī)則時(shí)...

TA貢獻(xiàn)1811條經(jīng)驗(yàn) 獲得超4個(gè)贊
您必須詳細(xì)了解它要檢查的內(nèi)容,但是標(biāo)準(zhǔn)的排序例程旨在非常非??斓剡\(yùn)行,因此它們不必檢查您所做的任何事情就可以了,而只是依靠它。如果您的比較返回不可能的結(jié)果,那么將不可能發(fā)生的事情-說它得到了一些比較的結(jié)果,并將其用作查看位置的索引,只有它“知道”可能的值并“知道”結(jié)果引用將存儲(chǔ)在有效存儲(chǔ)中,因此只需將其提取即可。Kaboom:SIGSEGV運(yùn)氣不錯(cuò)。如果運(yùn)氣不好,它將無聲地管理您的數(shù)據(jù)
- 3 回答
- 0 關(guān)注
- 548 瀏覽
添加回答
舉報(bào)