插入排序

思路:插入排序的基本操作就是將一個數據插入到已經排好序的有序數據中,從而得到一個新的、個數加一的有序數據,算法適用於少量數據的排序。是穩定的排序方法。插入算法把要排序的數組分成兩部分:第一部分已經排好序,第二部分是一個待插入元素。通過逐次比較將該元素插到合適的位置。直到數組末尾。平均時間複雜度爲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;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章