因此,我需要对向量进行排序,而不是手工操作,而是使用插入和擦除。
到目前为止,我的代码是
for (int x = 0; x < arr.size(); x++) {
for (int y = x; y < arr.size(); y++)
{
if ( arr[y] < arr[x])
{
arr.insert(arr.begin()+x,arr[y]);
arr.erase(arr.begin()+y+1);
}
}
}
,但是当它运行时,我的测试用例中出现超时,并为其中的3个工作(测试用例为245+长整数)。我必须使用向量,并且必须在设计中使用插入排序(查找最小交换以进行排序,但多数民众赞成从此处切入),我知道运行时很糟糕。
对于编译器来说,我在做什么错了?
答案 0 :(得分:1)
每次调用arr.insert
或arr.erase
时,都会得到O(n)复杂度。尝试改用std::swap (arr[x], arr[y])
。