【发布时间】:2011-05-15 01:41:24
【问题描述】:
我有一个带有 int 值的二维数组(向量的 ints 向量),例如这些
我想找到列值(不是行值)的最大值和最小值 最好使用 STL 算法
std::max_element, std::min_element
【问题讨论】:
-
是行向量还是列向量?这显然很重要。
-
列值的最大值是什么意思?列总和的最大值还是列最大值的向量?
我有一个带有 int 值的二维数组(向量的 ints 向量),例如这些
我想找到列值(不是行值)的最大值和最小值 最好使用 STL 算法
std::max_element, std::min_element
【问题讨论】:
创建一个比较某个列号的自定义函子,例如:
struct column_comparer
{
int column_num;
column_comparer(int c) : column_num(c) {}
bool operator()(const std::vector<int> & lhs, const std::vector<int> & rhs) const
{
return lhs[column_num] < rhs[column_num];
}
};
...
std::vector<std::vector<int>> v;
...
... // fill it with data
...
int column_num = 3;
int n = (*std::max_element(v.begin(), v.end(), column_comparer(column_num)))[column_num];
【讨论】:
std::vector<int> 和 v 的声明中的 ">" 字符之后添加一个额外的空格才能编译,除非您使用 C+ +0x。