简单的三大排序算法选择

Posted gdouzz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了简单的三大排序算法选择相关的知识,希望对你有一定的参考价值。

    前面系列文章

      插入排序: https://www.cnblogs.com/gdouzz/p/10759390.html

   选择排序: https://www.cnblogs.com/gdouzz/p/10759239.html

   冒泡排序:   https://www.cnblogs.com/gdouzz/p/10720451.html

  (二)个人总结

  1、选择排序和冒泡排序比较

  选择排序和冒泡排序的比较,选择排序的时间复杂度,不论最好最坏都是o(n²),是因为比较次数的原因,但它的交换次数是比冒泡排序要少的,所以在某些情况下,可能会比冒泡排序快一点。冒泡排序因为交换次数的问题,在平时的编程中基本也不会用到。但是相对来说,出场率要比选择排序高。

       2、为什么说插入排序会比冒泡排序好

            //插入排序//if (tempValue < arr[k])
                    //{
                    //    arr[k + 1] = arr[k];
                    //}
                    //else
                    //{
                    //    break;
                    //}
                    //上面插入排序,只需要一次赋值操作,
                        // if (arr[j] > arr[j + 1])
                        // {
                            // var temp = arr[j];
                            // arr[j] = arr[j + 1];
                            // arr[j + 1] = temp;
                        // }
                    //下面表面看都已经3次赋值了,并且交换操作对CPU不友好。
//为啥说,交换操作对CPU不友好呢,我们CPU的从内存里面加载数据的时候,一般是整块来加载的 //就是说会把相邻的数据都一块读到寄存器中(缓存中)。 //如果你是交换的话,当你一个数组非常庞大,假设第10项要和第10000项,一个在CPU的寄存器中, //一部分在内存或者外存,这里就会多一层时间消耗。

  插入排序和选择排序比较,不用比较了。

  总结:这三种简单的排序算法当中,如果要推荐,应该要优先使用插入排序,效率会更高。还有在日常编程中,冒泡排序和选择排序,几乎很少用到(如果在数据量很小的排序当中,这几个算法也不会有太大的区别,调用次数多了,才会稍微有点区别),对于我们程序员来说,应该要追求更高效的做法(在插入,冒泡,选择)中,做出合适的选择。

以上是关于简单的三大排序算法选择的主要内容,如果未能解决你的问题,请参考以下文章

Java实现三大简单排序算法

八大排序算法(交换排序选择排序和插入排序,这六种排序方法完成)与三大查找方法

排序算法-(冒泡选择插入算法)

三大经典排序 冒泡排序,选择排序,快速排序

选择排序(简单选择排序堆排序的算法思想及代码实现)

python学习选择排序算法简单代码