因此,在使用自定义比较器对向量进行排序时,我在边缘情况下遇到了这种非常奇怪的行为。
运行此代码时,它不会停止,而是永远运行:
int main() {
auto comp = [](int lhs, int rhs) {
return true;
};
vector<int> vec{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
sort(vec.begin(), vec.end(), comp);
for (int num : vec)
cout << num;
return 0;
}
但是,当我将 更改为true
时false
,它可以完美运行。
auto comp = [](int lhs, int rhs) {
return false;
};
更奇怪的是,当我减少0
要排序的 's 的数量时,它也可以完美地工作。(它适用于 16 或更少0
,当我再添加一个0
使其成为 17 时,程序不会再次停止。(如果长度超过 16,g++ 会切换到另一种排序算法吗?)
vector<int> vec{0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
为什么会这样?我是否遗漏了 C++sort()
函数中的一些重要概念?