您的位置:首页 > 其它

插入排序

2015-12-06 20:17 183 查看
思路:插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序。是稳定的排序方法。插入算法把要排序的数组分成两部分:第一部分已经排好序,第二部分是一个待插入元素。通过逐次比较将该元素插到合适的位置。直到数组末尾。平均时间复杂度为O(n^2)。最好时间复杂度为O(N)。

#include<iostream>
using namespace std;

void InsertSort(int* arr, int size)
{
for (int i = 1; i < size; i++)
{
int end = i - 1;
while (arr[end] > arr[end + 1] && end >= 0)
{
swap(arr[end], arr[end + 1]);
end--;
}
}
}

void Print(int* arr, int size)
{
for (int i = 0; i < size; i++)
{
cout << arr[i] << " ";
}
cout << endl;
}
int main()
{
int arr[10] = { 10, 16, 18, 12, 11, 13, 15, 17, 14, 19 };
InsertSort(arr, sizeof(arr) / sizeof(arr[0]));
Print(arr, sizeof(arr) / sizeof(arr[0]));
getchar();
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: