为什么使用二进制搜索的插入排序比使用线性搜索的插入排序慢?
使用线性搜索进行插入排序的代码:
void InsertionSort(int data[], int size)
{
int i=0, j=0, temp=0;
for(i=1; i<size; i++)
{
temp = data[i];
for (j=i-1; j>=0; j--)
{
if(data[j]>temp)
data[j+1]=data[j];
else
break;
}
data[j+1] = temp;
}
}
使用线性搜索进行插入排序的代码:
void InsertionSort (int A[], int n)
{
int i, temp;
for (i = 1; i < n; i++)
{
temp = A[i];
/* Binary Search */
int low = 0, high = i, k;
while (low<high)
{
int mid = (high + low) / 2;
if (temp <= A[mid])
high = mid;
else
low = mid+1;
}
for (k = i; k > high; k--)
A[k] = A[k - 1];
A[high] = temp;
}
}
尽管使用二分搜索的比较次数 = O(nlogn) 和使用线性搜索的比较次数 = O(n^2) 对于平均情况。
原始的插入排序是线性搜索的,而修改的插入排序是二进制搜索的。