思路:插入排序的基本操作就是將一個數據插入到已經排好序的有序數據中,從而得到一個新的、個數加一的有序數據,算法適用於少量數據的排序。是穩定的排序方法。插入算法把要排序的數組分成兩部分:第一部分已經排好序,第二部分是一個待插入元素。通過逐次比較將該元素插到合適的位置。直到數組末尾。平均時間複雜度爲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;
}