排序:Java实现快速排序原理及代码注释详解

简介: 排序:Java实现快速排序原理及代码注释详解

快速排序


1.简介:


快速排序是对冒泡排序的一种改进。它的最坏时间复杂度为O(n2),最好时间复杂度为O(nlogn),平均时间复杂度为O(nlogn),它是不稳定排序。


基本思想:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。


2.算法原理:


从数列中挑出一个元素,称为 “基准”;

重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区操作;

递归地把小于基准值元素的子数列和大于基准值元素的子数列排序。

结合动态图理解一下:

20190715215152724.gif



(图片来源:十大经典排序算法(动图演示)

3.代码实现:

public static void kuaiSu(int[] a,int low,int height){
        int i = low,j = height;
        if(low < height){
            int mark = a[low];
            while (i < j) {
                while (a[j] > mark && i < j){
                    j--;
                }
                if(i < j) {
                    a[i] = a[j];
                    i++;
                }
                while (a[i] < mark && i < j){
                    i++;
                }
                if(i < j) {
                    a[j] = a[i];
                    j--;
                }
            }
            a[i] = mark;
            kuaiSu(a,low,i - 1);
            kuaiSu(a,i+1,height);
        }
    }


测试一波:

package sort;
/**
 * @author yzh
 * @date 2019-07-15 20:36
 */
public class KuaiSu {
    public static void kuaiSu(int[] a,int low,int height){
        int i = low,j = height;
        if(low < height){
            int mark = a[low];
            while (i < j) {
                while (a[j] > mark && i < j){
                    j--;
                }
                if(i < j) {
                    a[i] = a[j];
                    i++;
                }
                while (a[i] < mark && i < j){
                    i++;
                }
                if(i < j) {
                    a[j] = a[i];
                    j--;
                }
            }
            a[i] = mark;
            kuaiSu(a,low,i - 1);
            kuaiSu(a,i+1,height);
        }
    }
    public static void main(String[] args) {
        int[] a = {4,-4,52,0,54,14,754};
        kuaiSu(a,0,a.length-1);
        for(int i = 0;i < a.length;i++){
            System.out.println(a[i]);
        }
    }
}

测试结果:


20190715215803858.png

4.优缺点:

  • 优点:极快,数据移动少;
  • 缺点:不稳定。
目录
相关文章
|
2天前
|
XML 前端开发 Oracle
16:JSP简介、注释与Scriptlet、Page指令元素、Include操作、内置对象、四种属性-Java Web
16:JSP简介、注释与Scriptlet、Page指令元素、Include操作、内置对象、四种属性-Java Web
8 2
|
2天前
|
Java
如何解决使用若依前后端分离打包部署到服务器上后主包无法找到从包中的文件的问题?如何在 Java 代码中访问 jar 包中的资源文件?
如何解决使用若依前后端分离打包部署到服务器上后主包无法找到从包中的文件的问题?如何在 Java 代码中访问 jar 包中的资源文件?
11 0
|
4天前
|
Java Spring
Java 效率编码 必备插件 Lombok 让代码更优雅
该内容是一个关于Lombok插件的教程摘要:介绍了Lombok用于减少Java开发中的模板代码,提升效率;讲解了如何在IntelliJ IDEA中安装Lombok插件,以及在pom.xml中添加依赖;并提到了@Data注解能自动生成getter/setter、equals、hashCode和toString方法,@Slf4j注解自动处理日志,@Builder用于构建对象,以及@AllArgsConstructor和@NoArgsConstructor注解生成构造函数。还鼓励探索更多Lombok的注解用法。
|
4天前
|
Java 关系型数据库 测试技术
Java代码一键生成数据库文档(案例详解)
Screw是一个自动化数据库文档生成工具,能根据数据库表结构快速生成简洁、多格式(HTML、Word、Markdown)的文档,支持MySQL、MariaDB等多数据库。它使用Freemarker模板,允许用户自定义样式。依赖包括HikariCP数据库连接池和对应JDBC驱动。通过在Java代码或Maven插件中配置,可方便生成文档。示例代码展示了如何在测试用例中使用Screw。文档效果依赖于数据库中的表和字段注释。
|
4天前
|
NoSQL Java API
java一行代码实现RESTFul接口
Spring Data REST是构建在Spring Data之上的库,可自动将repository转换为REST服务,支持JPA、MongoDB、Neo4j、GemFire和Cassandra。无需手动创建Service和Controller层。要开始,需配置JPA数据源,创建实体类和Repository接口。快速实现REST接口,只需引入spring-boot-starter-data-rest Maven依赖,并在Repository接口上添加@RepositoryRestResource注解。
|
5天前
|
Java
【Java探索之旅】我与Java的初相识(完):注释,标识符,关键字
【Java探索之旅】我与Java的初相识(完):注释,标识符,关键字
5 0
|
5天前
|
存储 安全 Java
【Java EE】CAS原理和实现以及JUC中常见的类的使用
【Java EE】CAS原理和实现以及JUC中常见的类的使用
|
7天前
|
设计模式 消息中间件 Java
Java 设计模式:探索发布-订阅模式的原理与应用
【4月更文挑战第27天】发布-订阅模式是一种消息传递范式,被广泛用于构建松散耦合的系统。在 Java 中,这种模式允许多个对象监听和响应感兴趣的事件。
23 2
|
7天前
|
Java 编译器 开发者
【JAVA】为什么代码会重排序
【JAVA】为什么代码会重排序
|
8天前
|
存储 自然语言处理 Java
【JAVA面试题】什么是代码单元?什么是码点?
【JAVA面试题】什么是代码单元?什么是码点?