学习Java绝对要懂的,Java编程中最常用的几种排序算法!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了学习Java绝对要懂的,Java编程中最常用的几种排序算法!相关的知识,希望对你有一定的参考价值。

今天给大家分享一下Java中几种常见的排序算法的Java代码

技术分享

推荐一下我的Java学习羊君前616,中959,最后444.把数字串联起来!     ,群里有免费的学习视频和项目给大家练手。大神有空时也会带带大家的,学Java的过程中一定要多问多记,不要怕问题,要去主动的解决问题。

冒泡排序

技术分享

选择排序

技术分享

插入排序

技术分享

归并排序

技术分享

例如:降序排{10,5,9,6}分为{10,5},{9,6}然后{5,10},{6,9}然后完成

快速排序

技术分享

就最后一个快速排序可能大家看不太懂,我就举个例子吧

开始输入以下数组

技术分享

创建变量i=0(指向第一个数据), j=5(指向最后一个数据), k=6(赋值为第一个数据的值)。

我们要把所有比k小的数移动到k的左面,所以我们可以开始寻找比6小的数,从j开始,从右往左找,不断递减变量j的值,我们找到第一个下标3的数据比6小,于是把数据3移到下标0的位置,把下标0的数据6移到下标3,完成第一次比较:

技术分享

i=0 j=3 k=6

接着,开始第二次比较,这次要变成找比k大的了,而且要从前往后找了。递加变量i,发现下标2的数据是第一个比k大的,于是用下标2的数据7和j指向的下标3的数据的6做交换,数据状态变成下表:

技术分享

i=2 j=3 k=6

称上面两次比较为一个循环。

接着,再递减变量j,不断重复进行上面的循环比较。

在本例中,我们进行一次循环,就发现i和j“碰头”了:他们都指向了下标2。于是,第一遍比较结束。得到结果如下,凡是k(=6)左边的数都比它小,凡是k右边的数都比它大:

技术分享

如果i和j没有碰头的话,就递加i找大的,还没有,就再递减j找小的,如此反复,不断循环。注意判断和寻找是同时进行的。

然后,对k两边的数据,再分组分别进行上述的过程,直到不能再分组为止。

注意:第一遍快速排序不会直接得到最终结果,只会把比k大和比k小的数分到k的两边。为了得到最后结果,需要再次对下标2两边的数组分别执行此步骤,然后再分解数组,直到数组不能再分解为止(只有一个数据),才能得到正确结果。

 

最后需要注意两点(Java学习交流羊君前六一六,中九五九,最后四4四.把数字串联起来!每天都会精挑细选一个项目新玩法出来详细讲解,分享!包括答疑解惑! )

 

  1. 冒泡排序与选择排序有点类似,都是先通过依次比较将最小/大的元素放到最后;不同的是冒泡排序一次操作中,每次比较后,若需要都进行位置交换;而选择排序是每次比较之后,将最小的值的位置记录下来,最后与末尾位置交换。

  2. 插入排序的特点是从序列的第二个元素开始,与第一个元素排序,完成一轮;第二轮从第三个元素,依次与前面比较,然后排序, 其实就是做冒泡排序。

  3. 以上均假设数组的长度为n

这几种排序算法,只是简单实现了排序的功能,还有待改进,望指教,大家有什么别的算法也可以分享一下技术分享

以上是关于学习Java绝对要懂的,Java编程中最常用的几种排序算法!的主要内容,如果未能解决你的问题,请参考以下文章

java中最常见的几种运行时异常,你get了吗?

Java小白入门200例97之Java Lambda的几种简写方式

QA要懂的Linux命令

Java小白入门200例106之遍历ArrayList的几种方式

Java小白入门200例108之遍历LinkedList的几种方式

Java中的几种设计模式