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(优化归并排序)
快速排序
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]
归并排序