全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

java数据结构与算法之快速排序详解

本文实例讲述了java数据结构与算法之快速排序。分享给大家供大家参考,具体如下:

交换类排序的另一个方法,即快速排序。

快速排序:改变了冒泡排序中一次交换仅能消除一个逆序的局限性,是冒泡排序的一种改进;实现了一次交换可消除多个逆序。通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

步骤:

1、从数列中挑出一个元素,称为 "基准"(pivot);
2、重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区(partition)操作。
3、递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序。

递归的最底部情形,是数列的大小是零或一,也就是永远都已经被排序好了。虽然一直递归下去,但是这个算法总会退出,因为在每次的迭代(iteration)中,它至少会把一个元素摆到它最后的位置去。

算法实现代码如下:

package exp_sort;
public class QuickSort {
  public static void Qsort(int array[], int left, int right) {
    int pos;
    if (left < right) {
      pos = quickSort(array, left, right);
      //递归排序
      Qsort(array, left, pos - 1);
      Qsort(array, pos + 1, right);
    }
  }
  /**
   * 一趟快速排序
   *
   * @param array
   * @param left
   * @param right
   * @return
   */
  public static int quickSort(int array[], int left, int right) {
    int low, high;
    int temp = array[left]; // 选择基准记录(枢纽元)
    low = left;
    high = right;
    while (low < high) {
      // high从右到左找小于temp的记录
      while (low < high && array[high] >= temp) {
        high--;
      }
      // 找到小于temp的记录则交换
      if (low < high) {
        array[low] = array[high];
        low++;
      }
      // low从左到右找到大于temp的记录
      while (low < high && array[low] < temp) {
        low++;
      }
      // 找到大于temp的记录,则交换
      if (low < high) {
        array[high] = array[low];
        high--;
      }
    }
    //将游标放在当前位置,此时low=high
    array[low] = temp;
    return low;
  }
  public static void main(String[] args) {
    // TODO Auto-generated method stub
    int array[] = { 38, 62, 35, 77, 55, 14, 35, 98 };
    Qsort(array, 0, 7);
    for (int i = 0; i < array.length; i++) {
      System.out.print(array[i] + " ");
    }
    System.out.println("\n");
  }
}

枢纽元的选取:

1、基本的快速排序:选取地一个元素作为枢纽元。实际中应尽量避免将第一个元素作为枢纽元(极端情况是:初始状态是已排好序或者反序的)。

2、随机化快排序 :  随机的选取枢纽元。

3、平衡快排 : 三数中值分割法:枢纽元的最好选择是数组中的中值,该中值,即左端、右端和中心位置上的三个元素的中值(推荐)。

算法分析:该算法是在实践中最快的一种排序算法,它的平均运行时间是O(N log N),该算法之所以快,主要是由于非常精炼和高度优化的内部循环。它的最坏情况的性能是O(N^2),但是这种情况可以改变。快速排序是一种分治的递归算法。该算法比归并排序算法排序快。

1、最坏情况的分析

当枢纽元是最小元素时,此时就相当于是对整个数组进行递归排序,时间复杂度为:O(N^2)

2、最好情况的分析

枢纽元正好位于中间,此时是对两个子数组进行递归排序,时间复杂度是:O(N log N),这和归并排序的分析完全相同。

3、平均情况的分析

时间复杂度是:O( N log N)

更多关于java算法相关内容感兴趣的读者可查看本站专题:《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》

希望本文所述对大家java程序设计有所帮助。


# java  # 数据结构  # 算法  # 快速排序  # java数据结构排序算法之归并排序详解  # java数据结构与算法之希尔排序详解  # java数据结构与算法之插入排序详解  # 浅析Java 数据结构常用接口与类  # Java数据结构之图(动力节点Java学院整理)  # Java数据结构之散列表(动力节点Java学院整理)  # Java常见基本数据结构概览  # 递归  # 放在  # 两部分  # 最坏  # 操作技巧  # 左端  # 是在  # 是一种  # 好了  # 相关内容  # 在这个  # 第一个  # 都要  # 多个  # 感兴趣  # 给大家  # 然后再  # 这种情况  # 总会 


相关文章: 如何在西部数码注册域名并快速搭建网站?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  如何选择高效可靠的多用户建站源码资源?  实例解析Array和String方法  魔方云NAT建站如何实现端口转发?  建站主机选购指南:核心配置与性价比推荐解析  在线制作视频的网站有哪些,电脑如何制作视频短片?  建站之星导航配置指南:自助建站与SEO优化全解析  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  家庭服务器如何搭建个人网站?  中山网站推广排名,中山信息港登录入口?  建站之星各版本价格是多少?  网站制作模板下载什么软件,ppt模板免费下载网站?  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  如何在自有机房高效搭建专业网站?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  建站之星好吗?新手能否轻松上手建站?  IOS倒计时设置UIButton标题title的抖动问题  宝塔建站后网页无法访问如何解决?  网站制作价目表怎么做,珍爱网婚介费用多少?  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  如何选择建站程序?包含哪些必备功能与类型?  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  建站之星导航如何优化提升用户体验?  营销式网站制作方案,销售哪个网站招聘效果最好?  外贸公司网站制作哪家好,maersk船公司官网?  建站之星如何快速解决建站难题?  网站制作哪家好,cc、.co、.cm哪个域名更适合做网站?  网站制作报价单模板图片,小松挖机官方网站报价?  建站org新手必看:2024最新搭建流程与模板选择技巧  如何用低价快速搭建高质量网站?  建站之星客服服务时间及联系方式如何?  如何通过FTP服务器快速搭建网站?  导航网站建站方案与优化指南:一站式高效搭建技巧解析  如何用好域名打造高点击率的自主建站?  枣阳网站制作,阳新火车站打的到仙岛湖多少钱?  如何通过老薛主机一键快速建站?  C#如何序列化对象为XML XmlSerializer用法  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  制作网站外包平台,自动化接单网站有哪些?  头像制作网站在线制作软件,dw网页背景图像怎么设置?  建站主机空间推荐 高性价比配置与快速部署方案解析  如何用已有域名快速搭建网站?  ,购物网站怎么盈利呢?  沈阳制作网站公司排名,沈阳装饰协会官方网站?  建站之星如何助力企业快速打造五合一网站?  ,有什么在线背英语单词效率比较高的网站?  如何设计高效校园网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。