c++ set使用多维坐标点结构

这篇博客讨论了在C++中使用set处理自定义结构,如二维坐标点时遇到的问题。作者指出,由于不正确的自定义小于运算符,set出现了重复的数据。解决方案是定义优先级,例如x轴优先于y轴进行比较。此外,作者提到在不需要关心数据大小关系,而是寻求唯一性时,unordered_set配合自定义hash函数和相等比较函数会更合适。
摘要由CSDN通过智能技术生成

set

我们知道STL中自带了俩个方便的关于set的模板类供我们使用。

  1. set——红黑树底层
  2. unordered_set——hashtable底层

在遇到自定义结构体的时候,比如二维坐标点,我遇到了一些小小的问题。

问题

我的set中出现了重复的数据结构。

struct Data{
   
	int x;
	int y;
	bool operator<(const Data&rhs)const
	{
   
		return x < rhs.x || y < rhs.y;
	}
};

我当时定义了这么一种小于的方式。导致我的set出现了问题。
原因很简单。这个小于的定义方式有问题

假设(0, 5) 和 (5, 0) 比较,按照上面的规则(0, 5) 是小于(5, 0)
但是如果(5, 0) 和(0, 5)比较,按照上面的规则则(5, 0)小于(0, 5)显然这是矛盾的。
其中具体的数学规律我还不是很清楚,但是能给出一个指导性的意见

即在类似的比较中,我们要定义优先级。即我们认为x为第一优先级,只要x小就小。如果第一优先级无法比较,再去比较第二优先级。


                
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值