如何对包含const值的向量进行排序

时间:2014-05-14 19:14:47

标签: c++ sorting vector

我有一个这样的矢量设置,我想对它进行排序:

#include <iostream>
#include <vector>
#include <algorithm> 

using namespace std;

int main()
{
    const int a =10;
    int b = 20;
    pair<const int, int> constPair1(a,b);
    b=30;
    pair<const int, int> constPair2(a,b);
    vector<pair<const int, int>> vec{constPair1,constPair2};
    sort(vec.begin(),vec.end());

    return 0;
}

不幸的是,由于const值,上面的排序无法编译。有什么方法可以对这个载体进行排序吗?或者我是不是创建了一个新的向量并将值复制过来了?

2 个答案:

答案 0 :(得分:6)

在C ++ 03中,std :: vector中的元素必须是可复制赋值的,并且在c ++中是可复制构造的。具有const成员的对不符合该要求,因此无效。编译器正确地重新输入它。

在C ++ 11中,std :: vector中的元素必须是可移动赋值和可移动构造的。无法移动具有const成员的对,从而导致代码无效。

答案 1 :(得分:0)

我决定利用const_castoverride=swap进行排序工作:

template <class KEY, class VALUE>
class Wrapper {
    std::pair<const KEY, VALUE> d_data;

  public:
    Wrapper& operator=(const Wrapper &rhs) {
        const_cast<KEY&>(d_data.first) = rhs.d_data.first;
        d_data.second = rhs.d_data.second;
    }

    std::pair<const KEY, VALUE>& data() { return d_data; }
    std::pair<const KEY, VALUE> const& data() const { return d_data; }
};

template <class KEY, class VALUE>
void swap(Wrapper<KEY, VALUE>& a, Wrapper<KEY, VALUE>& b) {
    using std::swap;
    swap(const_cast<KEY&>(a.data().first), const_cast<KEY&>(b.data().first));
    swap(a.data().second, b.data().second);
}