美文网首页编程往事
我与插入排序二三事

我与插入排序二三事

作者: 果冻虾仁 | 来源:发表于2017-09-14 00:08 被阅读11次
原写作时间 2013-03-27

关于排序的算法有很多。作为初学者。我在掌握了冒泡排序后掌握的第二个排序算法是插入排序。一个多月前看了一些资料,了解了排序的思想,然后自己摸索出了代码的写法。并一直这样写了这么久。直到今天看了《算法导论》的时候,才恍然大悟,原来自己一直写的插入排序并不十分正确。虽然思想是相通的。但是运行的效率却相差很多。
比如一个数列。用数组表示。a[n]。
我写的插入排序是这样

for(i=0;i<n;i++)  
{  
    scanf("%d",&a[i]);  
    for(j=0;j<i;j++)  
    {  
        if(a[i]<a[j])  
        {   
              t = a[i];  
             a[i] = a[j];  
             a[j] = t;  
        }  
}  

这样写是一种边初始化赋值编排序的写法。如果是处理一段已经序列。则直接写成

for(i=1;i<n;i++)  
for(j=0;j<i;j++)  
{  
    if(a[i]<a[j])  
    {   
        t = a[i];  
        a[i] = a[j];  
        a[j] = t;  
    }  
}  

//以上两种方法第二个for语句也可以改成

for(j-i-1;j>=0;j--)  
{  
    if(a[i]<a[j])  
    {  
        t = a[i];  
        a[i] = a[j];  
        a[j] = t;  
    }  
}  

看到这里你会发现这里也是用的插入排序的思想。只不过关键是在插入的处理上。我的算法比正统算法差了好多。大家都知道计算机的数据插入无法直接像加、减、乘、除、赋值那样一步到位。正规的写法是:

for(i=1;i<n;i++)  
  
 t=a[i];  
for(j=i-1;j>0;j--)  
{  
     if(a[j]>t)  
     a[j+1]=a[j];  
 }  
 a[i+1]=t;  

假设一次赋值运算的时间为1,然后在最坏的情况,逆序的时候,我原来的写法需要移动的次数分别为1、2、3……n-1。一共是n*(n-1)/2次。每次移动实际是三次赋值运算,时间为3倍n*(n-1)/2。而正规的的写法移动次数分别是1、2、3、……n-1每次移动做一次赋值运算。最后的“插入”也是一次赋值。所以时间一共是n*(n-1)/2。所以我原来的写法效率与之相差太多啦。

怎么样,同样的思想(额,其实是不完全相同),写出来的程序效率还是不同的。【以上内容仓促写就,或有讹误。】
关键点在于两者在于“插入”方法的处理上。我有这样一种设想,就是用链表的方式存储元素。插入的时候直接修改指针。时间效率或许会有提高。我也没验证。不过即使我的设想是正确的,可以肯定的是那将是一种牺牲空间的时间优化法。


后记 2017-09-13

现在看来当时写的分析比较拙劣。实际时间复杂度中的常数系数的大小是基本可以忽略的。

相关文章

  • 我与插入排序二三事

    关于排序的算法有很多。作为初学者。我在掌握了冒泡排序后掌握的第二个排序算法是插入排序。一个多月前看了一些资料,了解...

  • 我与🐸二三事

    我的青蛙叫嘟嘟 每次给他准备行李时,总会挑那些时间短的,去的近的,怕他一时半会儿回不来 他有他的老鼠朋友 他们会一...

  • 2018-06-20

    我与时间管理的二三事 进...

  • 我与先生二三事

    今天去面试一家民宿。在龙坞那边山上,因为刚好先生也休息,所以开车送我过去的,面试的时候他在外面等,本以为半个小时能...

  • 我与女儿二三事

    平日里我喜欢与女儿开玩笑,她也没有把我当大人敬畏着,也喜欢和我开玩笑。不知道从什么时候起,她对我的称呼不再是妈,而...

  • 我与女排二三事

    每次女排有大的赛事,心情都要随之激动一阵时间,期间每次打电话回家,妈妈对我个人事宜关注的火力,相对要弱一些,有大半...

  • 我与保险二三事

    保险,这个很多人陌生又熟悉的单词,其实赋予了许多的意义。

  • 我与“同桌”二三事

    我的“同桌"叫李仪,她是女儿,我是爸爸。我和女儿能做“同桌",你是不是觉得奇怪呢? 呵呵,我也没想到。起因是不久前...

  • 我与眼睛二三事

    今天去医院检查了我的眼睛。 医生说我得了轻微的干眼症。 我慌了,舌头有点打结,问她,“然、然后呢?” 医生深深地看...

  • 我与最爱二三事

    我喜欢春天的风,我喜欢路边懒洋洋的小猫,我喜欢鲜活的面孔,我喜欢独自沉浸在音乐里,我喜欢思考千奇百怪的问题...

网友评论

    本文标题:我与插入排序二三事

    本文链接:https://www.haomeiwen.com/subject/nklrsxtx.html