操作符重载- c++: next_permutation的比较函数
operator overloading - c++ : comparison function for next_permutation
我想在对象的向量上使用std::next_permutation()
。
为此,我必须定义一个比较函数,该函数定义两个对象之间的< operator
(否则它将使用具有不可预测行为的默认比较操作符)
但有时我得到两个相等的对象(根据我的标准),因此Object1 < Object2
和Object2 < Object1
都返回false
,因此next_permutation()无限地…
EDIT:这是我所拥有的一个简单示例(循环永远不会结束)
MyObject.h:
class MyObject {
int param;
MyObject(int i);
};
Main.cpp:
bool comparison (MyObject * o1, MyObject * o2) { return (o1->param < o2->param); }
int main(){
std::vector<MyObject*> myVector;
myVector.push_back(new MyObject(0));
myVector.push_back(new MyObject(1));
myVector.push_back(new MyObject(1));
std::sort(myVector.begin(), myVector.end(), comparison);
do{
printf("%i, %i, %i n", myVector[0]->param, myVector[1]->param, myVector[2]->param);
} while(std::next_permutation(myVector.begin(), myVector.end()), comparison);
return 0;
}
那么我该如何处理这种情况呢?默认的< operator
如何处理这种情况?
在你的代码中:
while(std::next_permutation(myVector.begin(), myVector.end()), comparison)
你的父母放错地方了
应该是
while(std::next_permutation(myVector.begin(), myVector.end(), comparison))
否则您使用默认比较执行std::next_permutation
,使用逗号操作符丢弃结果,然后返回始终为真(函数指针不为空)的comparison
但有时我有两个相等的对象
std::next_permutation
不需要一个唯一的元素范围。
因此,这应该可以工作。你做错了什么
那么我该如何处理这种情况呢?
修复你的错误。
当然,我们没有办法知道那是什么,因为您没有展示您的测试用例。
相关文章:
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么比较运算符如此快速
- 我可以使用 g++ 进行三种比较 (<=>) 吗?
- 比较字符数组
- 将模板化的类型与C++中的某些类/类型进行比较
- C++自定义比较函数
- 如何比较自定义类的std::变体
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- std::设置自定义比较器
- 布尔比较运算符是如何在C++中工作的
- C++将目录中的所有文件与::filesystem进行比较
- shell排序中的交换和比较
- 如何在C++中比较两个char数组
- catch框架有没有办法比较流或文件
- 从文件中读取多个字节,并将它们存储在C++中进行比较
- 智能指针作为无序映射键,并通过引用进行比较
- 比较if语句中的数组值和int值
- 对于循环变体比较
- 使用自定义比较函数使用std::sort()对矢量字符串进行排序时出现问题
- 比较两个大小不等的映射c++