码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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
    • 3
    • 4
    • 5

    输出
    在这里插入图片描述

    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];
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    但是这里我查了一下,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

  • 相关阅读:
    Verilog中什么是断言?
    如何通过工单管理系统提高服务质量和客户满意度?
    Qt应用开发(基础篇)——按钮基类 QAbstractButton
    React基础知识大汇总
    python 基础:读,写.CSV格式文件
    复制控制 copy control(非平凡的类)
    SpringBoot集成MyBatis-Plus + MyBatis-Plus代码生成器[MP系列] - 第490篇
    隆云通氨气传感器
    Tomcat 异步组件 —— Nio2Endpoint
    AI编码prompt编写及内在逻辑
  • 原文地址:https://blog.csdn.net/m0_46378271/article/details/126223101
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号