C_and_CPP 板


LINE

開發平台(Platform): (Ex: Win10, Linux, ...) 編譯器(Ex: GCC, clang, VC++...)+目標環境(跟開發平台不同的話需列出) 額外使用到的函數庫(Library Used): (Ex: OpenGL, ...) 問題(Question):關於PriorityQueue的自定義struct中 opertor overloading 問題 餵入的資料(Input): 預期的正確結果(Expected Output): 錯誤結果(Wrong Output):Comppiler Error 程式碼(Code):(請善用置底文網頁, 記得排版,禁止使用圖檔) 補充說明(Supplement): 版上已經有很多大大們討論關於 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,大部分都是談論解決方法,但沒有看到關於上述疑惑的說明 雖然有解決方案即可但還是希望有人可以解答這個無關痛癢的疑惑... 先謝謝大大們 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 61.222.86.91 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1560239661.A.746.html ※ 編輯: fatcat8127 (61.222.86.91 臺灣), 06/11/2019 15:55:55
1F:推 LPH66: 我的 #1SkteFdb 看有沒有解答到你的問題 06/11 16:02
2F:→ LPH66: 簡而言之就是 C++ STL 預設就是用 < 來問你 06/11 16:02
3F:→ firejox: 人家預設就std::less阿 06/11 18:18
4F:→ fatcat8127: 暸解 謝謝大大們 06/11 18:23
5F:推 xavier13540: 當初設計把less放在template第三格真的很鳥 正常狀況 06/12 12:08
6F:→ xavier13540: 下第二格也只會放vector不會放deque或其他東西 06/12 12:08
7F:→ fatcat8127: 經xavier13540一說還真的沒傳過vector以外的 06/12 21:15
8F:→ loveme00835: 你的正常狀況真不正常 06/12 23:31
9F:推 xavier13540: 樓上都用deque還是很少用到min-heap? 06/13 07:13
10F:推 LPH66: deque 相對 vector 的一個優點是容器增大時不需複製/移動 06/13 07:48
11F:→ LPH66: 到新的空間, 光這一點就很有理由在一些狀況下用 deque 了 06/13 07:49
12F:→ LPH66: 嘛, 如果你真的對 comparator 在第三格感到很困擾的話 06/13 07:57
13F:→ LPH66: C++17 的 deduction guide 可以由建構子參數型態去推模版 06/13 07:58
14F:→ LPH66: 然後 priority_queue 的建構子 comparator 都排在容器前面 06/13 08:00
15F:→ loveme00835: std::priority_queue 要的不是 vector 也不是 deque 06/13 09:54
16F:→ loveme00835: 而是迭代器滿足 LegacyRandomAccessIterator 概念, 06/13 09:57
17F:→ loveme00835: 代表當你有需要抽換 container/allocator 的時候才會 06/13 09:58
18F:→ loveme00835: 知道它當成第二個參數的用意 06/13 09:59
19F:推 xavier13540: 我知道 但std::set不會把allocator放在less前面 不知 06/13 15:32
20F:→ xavier13540: 道當初設計把heap的第二格放容器的意義 06/13 15:32
21F:→ loveme00835: 因為你把 container 和 container adaptor 搞混了 06/13 22:50
22F:→ xavier13540: 並沒有 我分得清楚這兩者 06/14 12:00
23F:→ loveme00835: 不一樣的東西怎麼會拿來比參數的位置? 因為常抽換的 06/14 12:23
24F:→ loveme00835: 型別本來就不同 06/14 12:23
25F:推 xavier13540: 因為兩個都是底層 不影響使用段得到的東西 06/15 20:32
26F:→ xavier13540: *端 06/15 20:32







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燈, 水草

請輸入看板名稱,例如:BuyTogether站內搜尋

TOP