如何对包含const值的向量进行排序
How to sort a vector containing const values
我有一个像这样的向量,我想对它进行排序:
#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
值的原因,上面的排序无法编译。有什么方法可以对这个向量排序吗?或者我被困在创建一个新的向量和复制值?
在c++ 03中,std::vector中的元素必须是可复制赋值和可复制构造的。带有const成员的pair不满足这一要求,因此无效。编译器拒绝它是正确的。
在c++ 11中,std::vector中的元素必须是可移动赋值和可移动构造的。带有const成员的pair不能移动,因此会导致无效代码。
我决定利用const_cast
, override=
和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);
}
相关文章:
- 将结构向量排序为子组
- C++数组与向量排序(在我的情况下,向量比数组慢~2.5倍(无优化))
- 如何在对向量排序后更改索引值?c++
- C++向量排序给出0作为输出
- 将许多向量排序在一起
- 根据一个向量对多个向量排序
- 编译错误向量排序和联合
- C++我自己的函数进行向量排序
- 将字符串的向量排序为日期"yyyymmdd"
- C++ 通过使用旧向量进行预排序来改进向量排序
- C 向量排序 .h .cpp中的单独文件
- 向量排序-c++
- 将向量排序到一个无序映射c++11中
- 向量的向量排序
- c++向量排序方法编译失败,返回预期表达式
- 如何对bitset向量排序
- 向量排序的基础上只有先
- 我如何以相同的方式对两个向量排序,而条件只使用其中一个向量
- 列表排序和结构体向量排序之间的性能差距.c++
- 如何基于第二个字符串对字符串向量的向量排序