首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >向量的排序元素,其中每个元素是一对

向量的排序元素,其中每个元素是一对
EN

Stack Overflow用户
提问于 2012-07-26 09:06:41
回答 2查看 3.7K关注 0票数 3

可能重复: 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++中这样做呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-07-26 09:10:48

代码语言:javascript
复制
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());
票数 4
EN

Stack Overflow用户

发布于 2012-07-26 09:12:09

代码语言:javascript
复制
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

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11665914

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档