Java获取数组最大值、Java8的Arrays.sort()原理

一、Java获取数组最大值

1.1 直接对比

最简单的当然是一个个找进行对比的方法啦~:

int max = Integer.MIN_VALUE;
for (int j = 0; j < arr.length; j++) {
    if (arr[j]>max) max = arr[j];
}
return max;

输出
在这里插入图片描述

1.2 使用Arrays.sort(arr);

当然还是有一些有趣的操作的,代码量较少的是使用Arrays.sort(arr);

import java.util.Arrays;	
	
    public static int MAX(int[] arr) {
        Arrays.sort(arr);
        return arr[arr.length-1];
    }

但是这里我查了一下,Arrays.sort(arr);的时间复杂度并不是O(n)

  • 如果要对数组进行排序的话自然Arrays.sort(arr)更方便

  • 但是如果只是取最大值的话,使用循环能达到小一点的O(n)的时间复杂度,

二、Java8的Arrays.sort()原理

2.1 Java 8使用双轴快排

这里使用的是Java 8版本,点进Arrays.sort()方法发发现使用的是双轴快排(DualPivotQuicksort)

在这里插入图片描述

时间复杂度绿色字体也说了是O(nlogn),通常要比传统的快排(也叫做单轴快排)快

在这里插入图片描述

双轴快排(DualPivotQuicksort)

双轴快排(DualPivotQuicksort),顾名思义有两个轴元素pivot1,pivot2,且pivot ≤pivot2,将序列分成三段:x < pivot1、pivot1 ≤ x ≤ pivot2、x >pivot2,然后分别对三段进行递归。这个算法通常会比传统的快排效率更高,也因此被作为Arrays.java中给基本类型的数据排序的具体实现。

2.2 Arrays.sort()在1.7中使用了经过改进的Timsort

Timsort的排序过程

  • 如果长度小于64直接进行插入排序
  • 首先遍历数组收集每个元素根据特定的条件组成一个run
  • 得到一个run之后会把他放入栈中
  • 如果栈顶部几个的run符合合并条件,就会触发合并操作合并相邻的两个run留下一个run
  • 合并操作会使用尽量小的内存空间和GALLOP模式来加速合并

run的概念

在这里插入图片描述

合并条件

在这里插入图片描述

参考:

关于Java:Arrays.sort()是否会增加时间复杂度和时空复杂度?

世界上最快的排序算法——Timsort

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值