插入排序
算法描述:
我们先来考虑一个问题,如果有一个已经有序的数列,假设我们有一个办法,能够插入一个新的数字到这个数组中,同时让数组仍然保持有序,那么要排序一个长度为n的数组,其实只要把这个数组除第一个元素外的所有元素都当成是后来插入的,利用前面说到的方法,进行n-1次的插入,之后这个数组就变成有序数组了(排序也就完成了)。这个方法被称作插入排序,因为我们总是把数字插入到一个已经有序的数列中去。
示例:
{3 , 1 , 6 , 8 , 5} //原数组
{1 , 3 , 6 , 8 , 5} //第一次插入(将3这个新数字插入原数组{1},相当于得到{1,3}){1 , 3 , 6 , 8 , 5} //第二次插入(将6这个新数字插入更新后的原数组{1,3},相当于得到{1,3,6}
{1 , 3 , 6 , 8 ,