gpt4 book ai didi

c++ - 集合中的二维整数坐标吗?

转载 作者:行者123 更新时间:2023-11-30 01:22:42 26 4
gpt4 key购买 nike

我有一个二维整数坐标列表(坐标对)。我想读入这些内容,然后确定是否已阅读某个点。

整数数据可能落在整数数据类型提供的范围内的任何位置,但实际数据点的数量会很少。因此,使用二维数组来跟踪哪些点已被读取是不切实际的。 set 似乎是执行此操作的好方法。

我当前实现此目的的代码如下:

#include <set>
#include <iostream>
using namespace std;

class grid_cell{
public:
int x,y;
grid_cell(int x, int y) : x(x), y(y) {}
grid_cell(){}
bool operator< (const grid_cell& a) const { return y<a.y || x<a.x; }
};

int main(){
set<grid_cell> bob;

bob.insert(grid_cell(1,1));
bob.insert(grid_cell(-1,1));
bob.insert(grid_cell(1,-1));
bob.insert(grid_cell(-1,-1));
cout<<bob.count(grid_cell(1,1))<<endl;
cout<<bob.count(grid_cell(-1,1))<<endl;
cout<<bob.count(grid_cell(1,-1))<<endl;
cout<<bob.count(grid_cell(-1,-1))<<endl;
}

但我知道有什么不对劲,因为我插入了单元格,后来集合告诉我它不知道。上面的输出应该都是真的,但是,相反,如下。

1
1
0 <-?????
1

我怀疑比较器有问题,但不确定如何解决。

有什么想法吗?

最佳答案

比较确实是错误的。它不满足所需的语义。尝试这样的事情:

bool operator< (const grid_cell& a) const { return x<a.x || (x==a.x && y<a.y); }

这是一篇关于这个主题的好文章:

http://www.drdobbs.com/cpp/a-strategy-for-defining-order-relations/240147625

关于c++ - 集合中的二维整数坐标吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15889984/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com