如果某种排序算法是不稳定的
墨初 知识笔记 142阅读
堆排序是稳定的排序算法吗?
答:堆排序 的话,也会存在跟上面一样的交换最大值的位置会导致不稳定.例如有大堆 8 8 6 5 2.先选出第一个最大值8,放最末尾.此时就不稳定了.因为第二个8就跑它前面去了。 所以,堆排序不是稳定的排序算法。
归并排序是稳定的排序算法吗?
答:所以,归并排序也是稳定的排序算法。 基数排序是按照低位先排序,然后收集;再按照高位排序,然后再收集;依次类推,直到最高位。 有时候有些属性是有优先级顺序的,先按低优先级排序,再按高优先级排序,最后的次序就是高优先级高的在前,高优先级相同的低优先级高的在前。 基数排序基于分别排序,分别收集,所以其是稳定的排序算法。 希尔排序是按照不同步长对元素进行插入排序,当刚开始元素很无序的时候,步长最大,所以插入排序的元素个数很少,速度很快;当元素基本有序了,步长很小, 插入排序对于有序的序列效率很高。 所以,希尔排序的时间复杂度会比O (n^2)好一些。
排序内容的稳定性和稳定性有什么区别?
答:2、如果排序的内容仅仅是一个复杂对象的某一个数字属性,那么稳定性依旧将毫无意义(所谓的交换操作的开销已经算在算法的开销内了,如果嫌弃这种开销,不如换算法好了? ) 3、如果要排序的内容是一个复杂对象的多个数字属性,但是其原本的初始顺序毫无意义,那么稳定性依旧将毫无意义。
如果使用某个排序算法对序列进行排序,得到的有序序列是什么?
答:如果使用某个排序算法对序列进行排序,得到的有序序列是: 红 2 依然位于绿 2 的左侧,这个排序算法就是稳定的;反之,如果红 2 和绿 2 的相对位置发生了改变,这个排序算法就是不稳定的。