您的位置:首页 > 其它

浅谈插入排序

2016-06-21 15:13 183 查看
插排其实挺简单的,理解起来比快排、归并排序容易多了,但是插排挺慢的,时间复杂度是O(n^2)。

它的思路就是从第i项起,假设前面的已经全部排好,这时候第i项一直往前移动,直到找到适合它的位置,然后插进去。移动期间需要不断的把前一位的值赋给当前位置,这样就可以避免到时候找到适合自己位置后还要重新走一遍原来的路,把各个数移位,节省了时间。当然如果你一定要先找到位置再来移位也是可以的。而且如果你要从第0位开始找位置也行的。

下面是我写的c++版本的代码:

template<typename T>
void insertsort(T &num[],int n) {
for (int i = 1; i < n; ++i) {
T temp = num[i];
for (int j = i - 1; j >= 0 && num[j] > temp; --j) {
num[j+1] = num[j];
num[j] = temp;
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  插入排序