使用Boost 或STL 對C 語言中的壓縮容器進行排序
簡介
此問題探討將多個向量或容器排序在一起,保持它們的元素對應而不複製它們的挑戰。目標是在不依賴元組或其他臨時資料結構的情況下實現這一目標。
原始問題
原始問題提出了一個特定的任務:對三個向量進行排序,同時確保每個向量中的元素以相同的順序重新排列。它明確排除將向量複製到元組中或實作自訂排序函數。由於迭代器的唯讀和非隨機存取性質,嘗試使用 boost::zip_iterator 或 boost::zip_range 失敗。
答案
A工作解決方案由interjay 提供,利用tupleit.hh庫:
此模板函數將容器組合成boostost ::iterator_range,其行為類似於元組迭代器,允許使用boost::sort:
進行排序未來的考慮因素
答案適用於序列容器(例如向量),但它會最好將其擴展到可排序容器,這需要random_access 和雙向TupleIterators。但是,標準排序演算法目前不支援雙向迭代器。
更新
目前可以混合類似序列的容器(例如序列和列表)。然而,合併列表需要一個在雙向迭代器上運行的排序演算法,而該演算法目前在標準庫中不可用。
以上是如何使用 Boost 或 STL 在 C 語言中同時對多個向量進行排序而不複製?的詳細內容。更多資訊請關注PHP中文網其他相關文章!