std::min_element 返回意外结果
std::min_element returning unexpected result
我想求一个向量的最小值:
#include <algorithm>
#include <iostream>
#include <vector>
using namespace std;
int main () {
vector<double> v{2, 0, 4};
double minT = *std::min_element(v.begin(), v.end(),
[](double i1, double i2) {
std::cout << "Comparing: " << i1 << " " << i2 << " " << ((i1 < i2)? i1:i2) << " " << '\n';
return (i1 < i2)? i1:i2;
});
cout << "Minimum is: " << minT << '\n';
}
但是这段代码的输出是:
Comparing: 0 2 0
Comparing: 4 2 2
Minimum is: 4
我做错了什么?那里有任何未定义的行为吗?
注意:我知道我不需要 lambda 函数。删除它 returns 预期结果 (0),但我的目标是拥有一个不考虑零的个性化最小函数。
如果第一个参数小于第二个参数,则比较器需要 return true
,而不是两个值中较小的一个。所以 return 语句应该只是
return i1 < i2;
我想求一个向量的最小值:
#include <algorithm>
#include <iostream>
#include <vector>
using namespace std;
int main () {
vector<double> v{2, 0, 4};
double minT = *std::min_element(v.begin(), v.end(),
[](double i1, double i2) {
std::cout << "Comparing: " << i1 << " " << i2 << " " << ((i1 < i2)? i1:i2) << " " << '\n';
return (i1 < i2)? i1:i2;
});
cout << "Minimum is: " << minT << '\n';
}
但是这段代码的输出是:
Comparing: 0 2 0
Comparing: 4 2 2
Minimum is: 4
我做错了什么?那里有任何未定义的行为吗?
注意:我知道我不需要 lambda 函数。删除它 returns 预期结果 (0),但我的目标是拥有一个不考虑零的个性化最小函数。
如果第一个参数小于第二个参数,则比较器需要 return true
,而不是两个值中较小的一个。所以 return 语句应该只是
return i1 < i2;