因为最近要准备头条和腾讯的面试,开始刷算法,可是自己还是练得太少,刷算法效率太低.不过无所谓了,每刷一道,就比以前的自己厉害一点.
今天的主题是插入排序,.这么简单的排序,却困扰了我很久.首先说一下理解
插入排序的原理就是,首先认定第一个元素是有序的,然后从第二个元素开始,往第一个元素合适的位置插(大于=放在后面,小于交换位置,放在前面)–>所以它是稳定的(遇到相等的不调整位置).
然后第一次插入就导致了一个后果—>前面两个元素都有序了,接着我们从第三个元素开始插入,从第二个元素开始,依次与第三个元素比较,插入到最合适的位置(即插入到刚好小于哪个元素的位置)
这样,循环N-1次(因为是从第二个元素开始的),就完成了N-1个元素的插入,完成了有序
接下来看代码,普通的实现
void swap(int &a,int &b)
{
int temp=a;
a=b;
b=temp;
}
void insert(int *arr,int n)
{
if(arr==NULL||n<2)
return;
for(int j=