算法导论学习 之 插入排序

刚刚开始系统学习算法导论和c++,每次学习的算法都用c++ 实现一边,加深理解,方便回顾。

先从最简单的插入排序开始吧:

code:

#include<iostream>
#include<vector>
#include<map>
using namespace std;
void Insertion_Sort(int * a,int length)
{
    int i,j,key;
    for(i = 1;i < length;i ++){
        key = a[i];
        j = i - 1;
        while(j >= 0&&a[j] > key){
            a[j + 1] = a[j];
            a[j] = key;
            j --;
        }
    }
}
int main(void)
{
    int a[10];
    int i;
    for(i = 0;i < 10;i ++)
        cin >> a[i];
    Insertion_Sort(a,10);
    
    for(i = 0;i < 10;i ++)
        cout << a[i] << " ";
    cout << endl;
    return 0;
}
原文地址:https://www.cnblogs.com/zhangjialu2015/p/5256525.html