力扣第36刷-第三大的数

简介: 力扣第36刷-第三大的数

Example 36

第三大的数

题目概述:给你一个非空数组,返回此数组中 第三大的数 。如果不存在,则返回数组中最大的数。

示例 1:

输入:[3, 2, 1]

输出:1

解释:第三大的数是 1 。

示例 2:

输入:[1, 2]

输出:2

解释:第三大的数不存在, 所以返回最大的数 2 。

示例 3:

输入:[2, 2, 3, 1]

输出:1

解释:注意,要求返回第三大的数,是指在所有不同数字中排第三大的数。

此例中存在两个值为 2 的数,它们都排第二。在所有不同数字中排第三大的数为 1 。

解题思路:将数组从大到小排序后,从头开始遍历数组,通过判断相邻元素是否不同,来统计不同元素的个数。如果能找到三个不同的元素,就返回第三大的元素,否则返回最大的元素。

示例代码如下:

public class TheThirdLargestNumber {
    /**
     * 给你一个非空数组,返回此数组中 第三大的数 。如果不存在,则返回数组中最大的数。
     * 示例 1:
     * 输入:[3, 2, 1]
     * 输出:1
     * 解释:第三大的数是 1 。
     * 示例 2:
     * 输入:[1, 2]
     * 输出:2
     * 解释:第三大的数不存在, 所以返回最大的数 2 。
     * 示例 3:
     * 输入:[2, 2, 3, 1]
     * 输出:1
     * 解释:注意,要求返回第三大的数,是指在所有不同数字中排第三大的数。
     * 此例中存在两个值为 2 的数,它们都排第二。在所有不同数字中排第三大的数为 1 。
     * 来源:力扣(LeetCode)
     * 链接:https://leetcode.cn/problems/third-maximum-number
     */
    public static void main(String[] args) {
        TheThirdLargestNumber ttln = new TheThirdLargestNumber();
        System.out.println(ttln.thirdMax(new int[]{3, 2, 1})); // 1
    }
    /**
     * 官方
     *
     * @param nums
     * @return
     */
    public int thirdMax(int[] nums) {
        Arrays.sort(nums);
        reverse(nums);
        for (int i = 1, diff = 1; i < nums.length; ++i) {
            if (nums[i] != nums[i - 1] && ++diff == 3) { // 此时 nums[i] 就是第三大的数
                return nums[i];
            }
        }
        return nums[0];
    }
    public void reverse(int[] nums) {
        int left = 0, right = nums.length - 1;
        while (left < right) {
            int temp = nums[left];
            nums[left] = nums[right];
            nums[right] = temp;
            left++;
            right--;
        }
    }
}
相关文章
|
开发框架 JavaScript 前端开发
vue首次加载白屏问题
vue首次加载白屏问题
403 0
|
存储 编解码 监控
VOS3000作用与功能
VOS3000是一套VoIP 运营支撑系统,系统拥有强大的功能集合及可靠的安全保障,可支撑 5000 路并发,适用于话务转发,企业终端,APP 业务,大型呼叫中心调度等多种业务形态,满足了大部分高并发大容量 VoIP 业务的需求。
3096 0
|
BI 数据处理 索引
Pandas基本操作:Series和DataFrame(Python)
Pandas基本操作:Series和DataFrame(Python)
505 1
|
10月前
|
传感器 人工智能 编解码
一文彻底拿捏PCB的发展历程
本文回顾了印制电路板(PCB)从20世纪初至今的发展历程,详述了各阶段的关键技术突破及其对电子产业的影响。从早期的手工焊接到现代的高密度互连(HDI)、柔性PCB和智能化集成,PCB技术不断演进,满足了电子设备小型化、高性能的需求,并推动了全球电子产业的快速发展。文章还探讨了环保制造工艺和可持续发展的趋势。
384 1
编译QCefView+VS2019+QT5.15.2
本文介绍了如何编译QCefView项目,并在VS2019和Qt 5.15.2环境下集成,包括编译结果、要点、cmake部署Qt的方法和相关参考链接。
954 2
编译QCefView+VS2019+QT5.15.2
|
前端开发 JavaScript API
React、Vue.js 和 Angular前端三大框架对比与选择
前端框架是用于构建用户界面的工具和库,它提供组件化结构、数据绑定、路由管理和状态管理等功能,帮助开发者高效地创建和维护 web 应用的前端部分。常见的前端框架如 React、Vue.js 和 Angular,能够提高开发效率并促进团队协作。
1163 4
|
NoSQL 关系型数据库 MySQL
[AIGC] 分布式锁及其实现方式详解与Python代码示例
[AIGC] 分布式锁及其实现方式详解与Python代码示例
476 1
|
JavaScript 前端开发 API
每个前端开发人员都必须知道的 7 个 Vue3 组件库!
每个前端开发人员都必须知道的 7 个 Vue3 组件库!
|
存储 算法 关系型数据库
三范式详解
三范式详解
380 0
|
Java
Java构造方法的深度解析
Java构造方法的深度解析
242 0