這種算法 比起 直接插入算法的好處是 減少了比較次數,因爲你當前插入的前面的列表中肯定是有序的,那麼可以通過折半查找來 得來 你應該插入的位置,再把元素集體完後面挪動。
比如 當前列表是 1, 3 , 9 ,7, 123.當你遍歷到7的時候 前面的1,3, 9 實際上已經有序,那麼根據折半查找算法可以很容易找到我們應該插入的位置是 9的前面,那麼只需要把9 往後面挪動一位,再把7 放到9的位置即可。
這是我自己寫的測試例子。 工作了這麼多年了, 現在在家沒事溫習一下以前的排序,大家可以給出更優的解決辦法,或者參與羣 C語言/C++/STL/linux/MFC/WTL 77278127 去探討。
下一篇繼續介紹排序算法。
template<typename T>
int get_pos(int start_pos, int end_pos, T * src, T value)
{
if (start_pos == end_pos - 1)
{
if (value >= *(src + start_pos))
{
return end_pos;
}
else
{
return start_pos;
}
}
else if (value < *(src + ((start_pos + end_pos) / 2)))
{
get_pos(start_pos, (start_pos + end_pos) / 2, src, value);
}
else if (value > *(src + ((start_pos + end_pos) / 2)))
{
get_pos((start_pos + end_pos) / 2, end_pos, src, value);
}
else if (value == *(src + ((start_pos + end_pos) / 2)))
{
return ((start_pos + end_pos) / 2);
}
}
template <typename T>
void sort(T *temp, int len)
{
for (int i = 1; i < len; i++)
{
if (*(temp + i) > *(temp + i - 1))
{
continue;
}
else
{
int pos = get_pos(0, i, temp, *(temp + i));
T t = (*(temp + i) );
memcpy(temp + pos + 1, temp + pos, sizeof(T) * (i - pos));
*(temp + pos) = t;
}
}
}
int main(int argc, char* argv[])
{
int src[10] = {1000, 3456, 200, 134, 2342342, 40, 80, -1, 0, 21 };
sort(src, 10);
for (int i = 0; i < 10; i++)
{
printf("%d ", src[i]);
}
system("pause");
return 0;
}