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


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

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

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

    冒泡排序

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

    选择排序

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

    插入排序

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

    归并排序

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

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

    快速排序

    学习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编程中最常用的几种排序算法

  • 相关阅读:
    js面试题-----页面布局
    js面试题-----原型和原型链
    js面试题-----运行环境
    js面试题-----开发环境
    js面试题-----事件及ajax
    js面试题-----DOM操作和BOM操作
    js面试题-----异步和单线程及其他知识点
    js面试题-----作用域与闭包
    js面试题-----变量类型和计算
    js学习总结----webapp之使用less构建响应式布局
  • 原文地址:https://www.cnblogs.com/Autumn-R/p/7048929.html
Copyright © 2020-2023  润新知