插入算法

插入学习算法是一种原地排序(sorted in place)的算法,亦即不用重新分配内存,在原数组或者vector中进行排序的。

其伪代码为

  1. 1 INSERTION-SORT(A)
    2 for j<-2 to length[A]
    3      do key<-A[j]
    4      //INSERT A[j] into the sorted sequence A[1..j-1]
    5      i<-j-1
    6      while i>0 and A[i]>key
    7          do A[i+1]<-A[i]
    8                i<-i-1
    9             A[i+1]<-key


    伪代码的好处在于看起来方便直观,而且在使用其他语言实现的时候也非常简单,是个非常好的表达自己思维的一种方式。

  2. 使用 数组的方式实现上述伪代码
#define SIZE 6

//插入算法的数组引用实现方式
void insertion_sort(int (&array)[ SIZE])
{
    int key;
    for(int j=1;j<SIZE;j++)
    {
        key=array[j];
        int i=j-1;
        while(i>=0&&array[i]>key)
        {
            array[i+1]=array[i];
            --i;
        }
        array[i+1]=key;
    }


   其中数组的引用作为形参的时候,必须固定数组大小,可以采用#define的形式。

3.采用vector的方式进行传参

void insert_sort(vector<int>&array) //当使用vector<int>array作为形参的时候,
                                                     //不能改变原vector中对象的内容,{                                    //当使用容器的引用的时候,可以正常改变
    //利用vector下标形式进行索引,同字符串和数组
    int key;
    for(int j=1;j<array.size();j++) 
    {                                
        key=array[j];
        int i=j-1;
        while(i>=0&&array[i]>key)
        {
            array[i+1]=array[i];
            --i;
        }
        array[i+1]=key;
    }


}

这里面有个不匹配的,就是array.size()是unsigned int形式的,但是j是int类型的,两者比较的时候容易出现问题。如果将i,j定义为unsigned类型的话,while循环中,i=0的时候,--i,为无符号类型,所以i变成了232,于是array[i]就会溢出。如果一定要用unsigned int i,j的话,那么在主函数中要设置一个岗哨。岗哨设置在下面可以看到。

4.采用迭代器

void insertSort(vector<int>&array)
{
    vector<int>::iterator it=array.begin()+1;
    for(it+=1;it!=array.end();++it)
    {
        int key=*it;
        vector<int>::iterator ita=it-1;
        while(ita>=array.begin()+1&&(*ita)>key)
        {
            *(ita+1)=*ita;
            --ita;
        }
        *(ita+1)=key;
    }
}

int main()
{
    vector<int> A;
    A.push_back(INT_MIN);   //通过设置岗哨,可以让程序继续运行下去。
    A.push_back(5);
    A.push_back(2);
    A.push_back(4);
    A.push_back(3);
    A.push_back(1);
    A.push_back(6);
    //insert_sort(A);
    insertSort(A);
    vector<int>::iterator it=A.begin()+1;
    while(it!=A.end())
    {
        cout<<*it<<"\t";
        ++it;
    }
    
}

 

posted @ 2015-11-03 12:56  学会走路  阅读(781)  评论(0编辑  收藏  举报