1
bool pred(int k, int l, int num1, int num2)  
{
return (num1 < num2);
}

int main()
{
   vector <int> nums;
   for (int i=50; i > 0; --i)
   {
      nums.push_back(i);
   }
   std::sort (nums.begin(), nums.end(), boost::bind(&pred, 5, 45));
}

我是一个boost新手。我正在学习使用 boost::bind,我想对一个整数向量进行排序,并去掉向量中大于 45 且小于 5 的所有元素。很难做到。如果有人可以帮助我做到这一点会很棒吗?

我面临问题的原因是因为我试图在迭代向量以对其进行排序时摆脱向量元素。我知道如果我先对其进行排序然后从中删除元素会容易得多。但我想这样做。任何帮助表示赞赏。

4

3 回答 3

4

你不能从sort.

删除之前或之后的元素sort

bool outOfRange(int low, int high, int num) {
    return low > num || num > high;
}

...

    nums.erase(
            std::remove_if(nums.begin(), nums.end(),
                    boost::bind(&outOfRange, 5, 45, _1)),
            nums.end()
        );

虽然你真的根本不需要boost::bind。哎呀,我们也可以让它更通用一点:

template<typename T, class cmp = std::less<T> >
struct outOfRange : std::unary_function<T, bool> {
    outOfRange(const T &low, const T &high) : low(low), high(high) {}
    bool operator()(const T &val) { return cmp()(val, low) || cmp()(high, val); }
    const T &low, &high;
}

...

    nums.erase(
            std::erase_if(nums.begin(), nums.end(), outOfRange<int>(5, 45)),
            nums.end()
        );
于 2009-11-04T23:05:51.600 回答
2

有很多方法可以做到这一点。最简单的方法是首先删除所有不需要的元素,然后排序:

bool outsideRange(int num, int min, int max)  
{
  return (num < min) || (num > max);
}

nums.erase(std::remove_if(nums.begin(),nums.end(),boost::bind(&outsideRange,_1,5,45) ) ); // See comments about remove-erase idiom.
std::sort(nums.begin(),nums.end());

请注意,当使用 boost bind 时,您需要包含占位符 (_1),它告诉它哪个参数是被迭代的参数。

如果您更喜欢一步,您可以有条件地将所有整数复制到一个多重集,它会为您对项目进行排序:

bool outideRange(int num, int min, int max)  
{
    return (num < min) || (num > max);
}

std::multiset numsInSet;
std::remove_copy_if(
   nums.begin(),
   nums.end(),
   std::inserter(numsInSet,numsInSet.begin()), 
   boost::bind(&outideRange,_1,5,45) );
于 2009-11-04T23:27:51.613 回答
0

您的想法不太可能,因为 std::sort 只能影响向量的顺序并且不能自己修改值。

我能想到的最接近你想要的是让所有有效值(>= 5 和 <= 45 的值)位于无效值之前,但同时对有效值和无效值进行排序。

bool pred(int min, int max, int num1, int num2)
{
    bool num1_valid = (num1 >= min) && (num1 <= max);
    bool num2_valid = (num2 >= min) && (num2 <= max);

    if (num1_valid == num2_valid)
    {
        return num1 < num2; 
    }
    else
    {
        return num1_valid;
    }
}
于 2009-11-04T23:21:40.783 回答