正如题主所说,为什么下面的代码将某些元素与它们自身进行比较?
#include <iostream>
#include <vector>
#include <algorithm>
class a {
public:
a(int value): value(value) {}
~a() {}
bool operator<(const a& rhs) const {
if(this->value == rhs.value)
std::cout << this << " " << this->value << "\t"
<< &rhs << " " << rhs.value << std::endl;
if(this->value < rhs.value)
return true;
return false;
}
int value;
};
int main(int argc, char* argv[]) {
std::vector<a> vec;
for(int i = 0; i < 17; i++)
vec.push_back(a(i));
std::sort(vec.begin(), vec.end());
return 0;
}
我在 Windows、Linux 和 OpenBSD 上尝试了上面的代码,似乎在 Windows 上它不会将元素与其自身进行比较,但在 Linux 和 OpenBSD 上它都会进行比较。我的猜测是这是因为使用了不同的库。
在 Linux 上我得到类似这样的输出:
0x96be0d0 8 0xbfc2945c 8
0xbfc2945c 8 0x96be0d0 8
If std::sort
实现为快速排序,有一种情况,您将当前元素与枢轴元素进行比较。我没有我的塞奇威克算法手头的,但我认为避免这种比较不会加速算法(或者比较不会损害算法的复杂性)。如果您愿意,我可以查看确切的报价。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)