• Collections.sort排序原理


     

    首先先进入.sort源码

    进入list.sort

    进入Arrays.sort

    如果没有指定Comparator 进入Arrays.sort

    LegacyMergeSort.userRequested为true 没有设置进入ComparableTimSort.sort
    看TimSort的代码与ComparableTimSort几乎一样,只是在对比的时候有些差异
    ComparableTimSort用Comparator来进行比较


    ComparableTimSort:

    TimSort:

    接着看下面,可以看到是否设置了LegacyMergeSort.userRequested为true 如果设置了则使用归并排序,如果未设置则使用TimSort(优化归并排序)

    插入排序

    单轴快排


    如果待排序的数组项数为0或1,直接返回。(递归出口)
    在待排序的数组中任选一个元素,作为中心点(pivot)。
    将小于pivot的元素,大于pivot的元素划分为开来。也就是将小于中心点的元素放在中心点前面,大于中心点的元素放在中心点后面。
    对前面小于pivot的元素进行快速排序,对大于pivot的元素进行快速排序。


    双轴快排


    int[] arr = { 20,40, 50, 11, 8, 7, 54, 1, 5 };

    基准数据 tmp=20 然后从数组两端开始扫描数据
    当队尾的元素大于等于基准数据时,向前挪动right指针
    如果队尾元素小于tmp了,需要将其赋值给left
    当队首元素小于等于tmp时,向前挪动left指针
    当队首元素大于tmp时,需要将其赋值给high
    当low和high相等,此时的low或high就是tmp的正确索引位置 直接赋值arr[low]


    归并排序

  • 相关阅读:
    SSM框架搭建(二) 创建MAVEN项目
    SSM框架搭建(一) JDK和MAVEN环境搭建
    Sublime Text3 手动 配置 NodeJs 环境
    spring-petclinic性能调优实战(转)
    algs4 使用 DrJava 编写 Hello World on Windows
    系统学习数据结构算法
    Algorithm 学习环境准备
    Gradle构建多模块项目
    使用 Gradle 构建 Java 项目
    Gradle目录结构详解
  • 原文地址:https://www.cnblogs.com/zyh-s/p/13253475.html
Copyright © 2020-2023  润新知