C_and_CPP 板


LINE

※ 引述《fatcat8127 (胖胖貓)》之銘言: : 版上已經有很多大大們討論關於 PriorityQueue Compare Function 的解決問題, : 我將相關文章整理後再提出問題,以下說明僅憑我個人理解,不精確還請大大們指正。 : (1) priority_queue<int,vector<int>> PQ; : 預設的 priority_queue 是 max_heap,假若想實現 min_heap 時可以搭配 greater<int> : #include<functional> : priority_queue<int,vector<int>,greater<int>> PQ; : 參考這篇( https://pse.is/ECW72 ):overload greater function : bool operator>(const struct_name &one,const struct_name &rhs){ : return one.dis>rhs.dis; : } : priority_queue<PAIR,vector<PAIR>,greater<vector<PAIR>::value_type>> PQ; : (2) 自定義 function : struct COMP{ : bool operator()(const PAIR &lhs,const PAIR &rhs){ return lhs.dis>rhs.dis; } : }; : priority_queue<PAIR,vector<PAIR>,COMP> PQ; : (3) 將定義方式寫在 struct 內 : struct PAIR{ : int id; double dis; : PAIR(int a=0,double b=0):id(a),dis(b){} : // (1) overload operator "less than", but unable to overload "greater than" : bool operator<(const PAIR &rhs)const{ return dis<rhs.dis; } : }; : priority_queue<PAIR,vector<PAIR>> PQ; : 上述是以ZJ-c942為例,用不同方式宣告使用 PriorityQueue。 : 附上程式碼:https://ideone.com/lYQ8bo : 我的問題:為何(3)將定義方式寫在 strcut 內的這種方式, : overload operator時 只能是">"不能是"<",雖然說相關的operator都可以從"<"轉換 : 查了一下 StackOverflow,大部分都是談論解決方法,但沒有看到關於上述疑惑的說明 : 雖然有解決方案即可但還是希望有人可以解答這個無關痛癢的疑惑... 先謝謝大大們 簡單說結論: 非不得已不要重載 operator<() 重載運算子應該被視為最後的解決方案, 為什麼呢? 因為除了 assignment operator 以外, 其餘的運算子都可以在類別本體以外 作宣告, 亦即: 即使不是類別作者也可以隨意重載運算子. 如果你 確定想這麼做, 以宣告的位置來分, 有 4 種情境需要注意: namespace n1 { struct meow { (1) bool operator<(const meow&) const; }; (2) bool operator<(const meow&, const meow&); } (3) bool operator<(const n1::meow&, const n1::meow&); namespace n2 { (4) bool operator<(const n1::meow&, const n1::meow&); } 先不說無法明確表達語意這件事; 光是讓呼叫能正常編譯就困難重 重 (想想看為什麼). 不過也因為這樣高度的客製化彈性, 我們甚至 可以選擇性地讓編譯器呼叫想要的運算子實作: https://wandbox.org/permlink/mXhfObcCglfDxPdY 標準函式庫裡類似的例子有命名空間 std::rel_ops 和 std::string_literals. 把握 overload resolution 規則, 可以作 到改變 std::less<T> 的行為: https://wandbox.org/permlink/0Fd5SrhjOPQ2LztO 因此開發/使用這類 function object 時有幾點注意事項: 開發者 1. 不要依賴運算子造成語意不明, 用 Argument-dependent lookup (ADL) 來找到類別作者所設計, 或者覺得合適的 函式呼叫 2. 如果非要依賴某些運算子, 儘量減少種類和參數組合 使用者 1. 不要假設底層的實作為何 2. 即使已經知道底層實作, 確保想要的函式有在編譯器呼 叫候選名單裡 最後還是建議原po自己寫個類別作比較啦 -- P1389R0: Guidelines for Teaching C++ to Beginners https://bit.ly/2GvDWKb SG20 Education and Recommended Videos for Teaching C++ https://www.cjdb.com.au/sg20-and-videos --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 123.193.76.216 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1560361067.A.C9B.html ※ 編輯: poyenc (123.193.76.216 臺灣), 06/13/2019 01:45:02
1F:推 fatcat8127: 感謝大神的解釋 06/14 18:50







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Boy-Girl站內搜尋

TOP