【发布时间】:2017-09-04 09:36:21
【问题描述】:
我有一组配对,我想在 l 和 r 之间的配对的第二个条目中找到最大的数字。
这就是集合的样子:myset = [(0,2),(1,1),(2,4),(3,0),(4,3)]
这是我尝试过的:
#include <iostream>
#include <set>
using namespace std;
#define INPUT1(x) scanf("%d", &x)
#define INPUT2(x, y) scanf("%d%d", &x, &y)
#define OUTPUT1(x) printf("%d\n", x);
bool cmp(pair<int, int> A, pair<int, int> B) {
return A.second < B.second;
}
int main(int argc, char const *argv[]) {
int n;
INPUT1(n);
set< pair<int,int> > myset;
set< pair<int,int> >::iterator it;
for (int i = 0; i < n; i++) {
int val;
INPUT(val);
myset.insert(make_pair(i, val));
}
int l, r;
INPUT2(l, r);
int max = std::max_element(myset.begin()+l, myset.begin()+r+1, cmp)->second;
OUTPUT1(max);
}
这不起作用,但对于 l = 1 和 r = 3,我想要的是 max 等于 4。
我收到以下错误:
invalid operands to binary expression
('iterator' (aka '__tree_const_iterator<std::__1::pair<int, int>, std::__1::__tree_node<std::__1::pair<int, int>, void *> *, long>') and 'int')
【问题讨论】:
-
如果订购了
std::set。它要求您提供一个排序谓词。如果您不想 t 提供一个,请使用数组或向量。