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

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

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

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

冒泡排序数组

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

选择排序学习

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

插入排序3d

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

归并排序视频

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

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

快速排序排序

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

就最后一个快速排序可能你们看不太懂,我就举个例子吧变量

开始输入如下数组循环

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

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

咱们要把全部比k小的数移动到k的左面,因此咱们能够开始寻找比6小的数,从j开始,从右往左找,不断递减变量j的值,咱们找到第一个下标3的数据比6小,因而把数据3移到下标0的位置,把下标0的数据6移到下标3,完成第一次比较:

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

i=0 j=3 k=6

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

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

i=2 j=3 k=6

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

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

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

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

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

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

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

 

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

 

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

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

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

这几种排序算法,只是简单实现了排序的功能,还有待改进,望指教,你们有什么别的算法也能够分享一下学习Java绝对要懂的,Java编程中最经常使用的几种排序算法

相关文章
相关标签/搜索