【问题标题】:How to find the maximum in std::set< pair<int, int> > in a given range?如何在给定范围内找到 std::set< pair<int, int>> 的最大值?
【发布时间】: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 提供一个,请使用数组或向量。

标签: c++ c++11 stl set


【解决方案1】:

max_element 返回一个 iterator 到最大元素。更不用说 set 的元素是对的,而不是单个整数。

正确的写法是:

int max = std::max_element(myset.begin()+l, myset.begin()+r+1, cmp)->second;

【讨论】:

  • 我相应地修改了我的代码,但我仍然得到同样的错误。我在我的问题中添加了可编译代码。
  • 这不是正确的方法。它甚至根本不应该编译。
【解决方案2】:

您不能以这种方式使用std::max_element。原因是std::set提供了双向迭代器,而不是随机访问迭代器,所以myset.begin()+l之类的东西是被禁止的。

你应该使用这样的东西:

auto mx = std::numeric_limits<int>::min();

auto first = std::cbegin(myset);
std::advance(first, lf);

auto last = std::cbegin(myset);
std::advance(last, rg + 1);

for (auto it = first; it != std::cend(myset) && it != last; ++it) {
    mx = std::max(mx, it->second);
}

【讨论】:

    【解决方案3】:

    如果第一个小于第二个,比较函数应该返回 TRUE 修复

    bool cmp(pair<int, int> A, pair<int, int> B) {
        return A.second < B.second;
    }
    

    【讨论】:

    • 哦,是的,这就是我在我的代码中的内容,有问题地写错了。但我收到此错误invalid operands to binary expression
    • 好的,我马上做。
    • set::iterator不能像myset.begin()+x这样使用,只能是++
    【解决方案4】:

    使用嵌入迭代器的函数对象仍然可以加速搜索最大值:

    class Max {
    public :
      Max (std::set<std::pair<int, int> >::const_iterator& imax, std::set<std::pair<int, int> >::const_iterator& i) : imax_ (imax), i_ (i), max_ (0) {}
      ~Max () {}
      void operator () (const std::pair<int, int>& p) {
        if (p.second > max_) {
          imax_ = i_;
          max_ = p.second;
        }
        ++i_;
      }
    private :
      std::set<std::pair<int, int> >::const_iterator& imax_;
      std::set<std::pair<int, int> >::const_iterator& i_;
      int max_;
    };
    

    测试程序:

    int main (int argc, char* argv []) {
      std::pair<int, int> tmp [3] = {std::pair<int, int> (2, 1), std::pair<int, int>(3, 4), std::pair<int, int>(5, 2)};
      std::set<std::pair<int, int> > s (tmp, tmp+3);
      size_t l (0), r (3);
      std::set<std::pair<int, int> > ::const_iterator imax (s.begin ()), i(s.begin ()), end (s.end ()), il (s.begin ()), ir (s.begin ());
      std::advance (il, l);
      std::advance (ir, r+1); 
      std::for_each (il, ir, Max (imax, i));
      std::cout << "*imax == (" << imax->first << ", " << imax->second << ")" << std::endl;
    }
    

    【讨论】:

      猜你喜欢
      • 2010-11-23
      • 1970-01-01
      • 2013-11-23
      • 1970-01-01
      • 1970-01-01
      • 2021-10-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多