对向量的元素进行排序,其中每个元素都是一对[重复]

Posted

技术标签:

【中文标题】对向量的元素进行排序,其中每个元素都是一对[重复]【英文标题】:Sorting elements of vector where each element is a pair [duplicate] 【发布时间】:2012-07-26 09:06:41 【问题描述】:

可能重复:How do I sort a vector of pairs based on the second element of the pair?

我有一个这种类型的向量:vector< pair<float, int> > vect; 我想根据浮点值的降序(对的第一个值)对其元素进行排序。 比如vect = [<8.6, 4>, <5.2, 9>, <7.1, 23>],排序后我想拥有:[<5.2, 9>, <7.1, 23>, <8.6, 4>] 我怎样才能在 C++ 中简单地做到这一点?

【问题讨论】:

函数,它取第一个元素并进行比较。你有可能吗? (之后可以任意实现排序功能或使用boost等库) 看看这个。这是一个提升解决方案 -> ***.com/questions/279854/… 【参考方案1】:
struct cmp_by_first 
  template<typename T>
  bool operator<(const T& x, const T& y) const  return x.first < y.first; 
;

std::sort(vect.begin(), vect.end(), cmp_by_first());

【讨论】:

【参考方案2】:
std::vector<std::pair<float, int>> vect = 

    std::make_pair(8.6, 4),
    std::make_pair(5.2, 9),
    std::make_pair(7.1, 23)
;
std::sort(vect.begin(), vect.end(), [](const std::pair<float, int>& first, const std::pair<float, int>& second)

    return first.first < second.first;
);
for (const auto& p : vect)

    std::cout << p.first << " " << p.second << std::endl;

C++11.

http://liveworkspace.org/code/5f14daa5c183f1ef4e349ea26854f1b0

【讨论】:

既然是 c++11,你可以说:std::vector > vect = 8.6, 4, 5.2, 9, 7.1, 23;

以上是关于对向量的元素进行排序,其中每个元素都是一对[重复]的主要内容,如果未能解决你的问题,请参考以下文章

我如何按类属性对C++向量数组进行排序[重复]

如何根据对的第二个元素对对的向量进行排序?

在c ++中给出两个整数向量(相同的大小和类型),我想从最小到最大的元素对一个进行排序并更改第二个向量的顺序[重复]

算法-冒泡排序

排序-冒泡排序

将数组存储在向量中并对元素进行排序[关闭]