以下是我的插入排序代码:
void InsertionSort(vector<int> & ioList)
{
int n = ioList.size();
for (int i = 1 ; i < n ; ++i)
{
for (int j = 0 ; j <= i ; ++j)
{
//Shift elements if needed(insert at correct loc)
if (ioList[j] > ioList[i])
{
int temp = ioList[j];
ioList[j] = ioList[i];
ioList[i] = temp;
}
}
}
}
该算法的平均复杂度为 O(n^2)。
根据我对大 O 表示法的理解,这是因为在这种情况下我们运行了两个循环(外部一个 n-1 次,内部一个 1,2,...n-1 = n(n-1)/2 次,因此算法的无症状复杂度为 O(n^2)。
现在我已经读过最好的情况是输入数组已经排序的情况。在这种情况下,算法的大 O 复杂度是 O(n)。但我不明白这是怎么可能的,因为在这两种情况下(平均情况和最佳情况)我们都必须运行相同次数的循环并且必须比较元素。唯一避免的是元素的移动。
那么复杂度计算是否也涉及到这个交换操作的一个组件呢?