[multiindex] - lower_bound/upper_bound return wrong results
data:image/s3,"s3://crabby-images/e0dd9/e0dd9652d120b4a3e046f168bde564ac79d11fd6" alt=""
Hello,
The example below should print out only the items {1.0, true} and {2.0,
true} but not {1.5, false}.
What is going wrong?
Regards,
Oliver
#include <algorithm>
#include <iostream>
#include <iterator>
#include <cstdlib>
#include <stdexcept>
#include <utility>
#include
data:image/s3,"s3://crabby-images/3b660/3b6606c2b4d7e319cdf2a8c6039a458c14e83916" alt=""
Oliver.Kowalke@qimonda.com wrote:
Hello, The example below should print out only the items {1.0, true} and {2.0, true} but not {1.5, false}. What is going wrong?
The result is correct. Composite keys do comparison from left to right: only when the weight is equal is the assignability even considered for sorting. Thus, {1.5, false} sorts between {1.0, true} and {2.0, true} and thus is part of your range. Switch the order in your composite key and you'll get the results you expect: mi::composite_key< item, mi::const_mem_fun< item, bool, &item::asignable >, mi::const_mem_fun< item, double, & item::weight > > Sebastian Redl
participants (2)
-
Oliver.Kowalke@qimonda.com
-
Sebastian Redl