首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >向量排序向量

向量排序向量
EN

Stack Overflow用户
提问于 2013-01-19 22:23:57
回答 4查看 57.1K关注 0票数 21

我有过

代码语言:javascript
复制
    vector<vector<int>> vec 

在我的c++应用程序中。

每一个整数向量作为“大”向量的一个元素都有4个INT值。我想根据ints的内容向量的第三个值对vec进行排序(我指的是每一个“内部”向量第三元素)--它有可能吗?

编辑

假设我有一个功能

代码语言:javascript
复制
COST(vector<int>)

它根据我的向量值计算一些值--我也可以在比较参数中使用它吗?这会帮我更多的忙。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2013-01-19 22:28:31

当然是了。std::sort可以接受第三个参数,即排序时使用的比较函数。例如,您可以使用lambda函数:

代码语言:javascript
复制
std::vector<std::vector<int>> vec;
// Fill it

std::sort(vec.begin(), vec.end(),
          [](const std::vector<int>& a, const std::vector<int>& b) {
  return a[2] < b[2];
});

或者,您可以传递任何其他可使用签名bool(const std::vector<int>&, const std::vector<int>&)调用的内容,例如函子或函数指针。

编辑响应:只需将COST函数应用于ab

代码语言:javascript
复制
std::sort(vec.begin(), vec.end(),
          [](const std::vector<int>& a, const std::vector<int>& b) {
  return COST(a) < COST(b);
});
票数 52
EN

Stack Overflow用户

发布于 2013-01-19 23:14:41

如果要按成本比较这两个向量,请尝试如下:

代码语言:javascript
复制
bool predicate(const std::vector<int>& a, const std::vector<int>& b)
{
    return COST(a) < COST(b);
}

备注:

  • 以上也适用于C++98,我不确定C++11的使用有多广泛,以及您是否有一个兼容的编译器。否则,当然也可以像sftrabbit建议的那样使用lambda表达式。
  • 您没有说明成本回报,我只是假设了一些可排序的值,比如float或long。
  • 我希望您在将向量传递给成本()时不要复制它,这将是非常低效率的。
  • 成本意味着一个宏,就像所有的UPPERCASE_NAMES。不要使用宏。函数不要使用宏名称。
票数 4
EN

Stack Overflow用户

发布于 2020-10-11 18:17:56

sort(vec.begin(), vec.end(), comp);

其中comp是:

代码语言:javascript
复制
static bool comp(const vector<int>& vec1, const vector<int>& vec2){
    return vec1[2] < vec2[2];
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14419520

复制
相关文章

相似问题

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