插入排序与插入/擦除? (因此,我需要对向量进行排序,而不是手动执行插入操作,而是使用插入和擦除。)

时间:2019-04-09 23:26:11

标签: c++

因此,我需要对向量进行排序,而不是手工操作,而是使用插入和擦除。

到目前为止,我的代码是

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+长整数)。我必须使用向量,并且必须在设计中使用插入排序(查找最小交换以进行排序,但多数民众赞成从此处切入),我知道运行时很糟糕。

对于编译器来说,我在做什么错了?

1 个答案:

答案 0 :(得分:1)

每次调用arr.insertarr.erase时,都会得到O(n)复杂度。尝试改用std::swap (arr[x], arr[y])