我在boost::multi_index_container
同时使用随机访问和 orderd_unique 时遇到问题。(我很抱歉这个冗长的问题,但我想我应该举个例子..)
这里有一个例子:假设我想在工厂中生产 N 个对象,并且对于每个对象我都有一个需要满足的需求(这个需求在创建多索引时是已知的)。好吧,在我的算法中,我得到了中间结果,我将其存储在以下类中:
class intermediate_result
{
private:
std::vector<int> parts; // which parts are produced
int used_time; // how long did it take to produce
ValueType max_value; // how much is it worth
};
向量描述parts
了产生了哪些对象(它的长度是 N,并且它在字典上比我的 coresp 需求向量小!) - 对于每个这样的向量,我也知道 used_time。此外,我得到了这个生成对象向量的值。
我有另一个约束,所以我不能生成每个对象——我的算法需要intermediate_result
在数据结构中存储几个对象。在这里boost::multi_index_container
使用,因为parts
和used_time
描述了一个唯一的intermediate_result
(并且它在我的数据结构中应该是唯一的)但是这max_value
是我必须考虑的另一个索引,因为我的算法总是需要intermediate_result
最高的max_value
。
所以我尝试将boost::multi_index_container
withordered_unique<>
用于我的“parts&used_time-pair”和ordered_non_unique<>
我的max_value
(不同intermediate_result
的对象可能具有相同的值)。
问题是:决定哪个“parts&used_time-pair”更小所需的谓词std::lexicographical_compare
在 my -vector 上使用,因此对于许多-objectsparts
来说非常慢。intermediate_result
但是会有一个解决方案:我对每个对象的需求不是那么高,因此我可以在每个可能的部分向量上存储中间结果唯一的used_time
.
例如:如果我有一个需求向量( 2 , 3 , 1)
,那么我需要一个数据结构来存储(2+1)*(3+1)*(1+1)=24
可能的部分向量,并且在每个这样的条目上都有不同的 used_times,它们必须是唯一的!(存储最小的时间是不够的——例如:如果我的额外限制是:满足给定的生产时间)
但是如何将random_access<>
-index 与ordered_unique<>
-index 结合使用?
(Example11在这方面没有帮助我..)