力扣(数组)第三大数

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

示例 1:

输入:[3, 2, 1]
输出:1
解释:第三大的数是 1 。

示例 2:

输入:[1, 2]
输出:2
解释:第三大的数不存在, 所以返回最大的数 2 。

示例 3:

输入:[2, 2, 3, 1]
输出:1
解释:注意,要求返回第三大的数,是指在所有不同数字中排第三大的数。
此例中存在两个值为 2 的数,它们都排第二。在所有不同数字中排第三大的数为 1 。

题解:

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

class Solution {
    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--;
        }
    }
}
方法二:有序集合

我们可以遍历数组,同时用一个有序集合来维护数组中前三大的数。具体做法是每遍历一个数,就将其插入有序集合,若有序集合的大小超过 3,就删除集合中的最小元素。这样可以保证有序集合的大小至多为 3,且遍历结束后,若有序集合的大小为 3,其最小值就是数组中第三大的数;若有序集合的大小不足 3,那么就返回有序集合中的最大值。

class Solution {
    public int thirdMax(int[] nums) {
        TreeSet<Integer> s = new TreeSet<Integer>();
        for (int num : nums) {
            s.add(num);
            if (s.size() > 3) {
                s.remove(s.first());
            }
        }
        return s.size() == 3 ? s.first() : s.last();
    }
}

相关推荐

  1. 组)

    2024-04-02 17:12:03       41 阅读
  2. 215 数组k

    2024-04-02 17:12:03       28 阅读
  3. 题库6题:之和

    2024-04-02 17:12:03       49 阅读
  4. -之和

    2024-04-02 17:12:03       56 阅读
  5. 233题“数字1的个

    2024-04-02 17:12:03       30 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-02 17:12:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-02 17:12:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-02 17:12:03       82 阅读
  4. Python语言-面向对象

    2024-04-02 17:12:03       91 阅读

热门阅读

  1. android QtScrcpy 共享屏幕 获取本地Address

    2024-04-02 17:12:03       33 阅读
  2. Docker中安装PostgreSQL

    2024-04-02 17:12:03       43 阅读
  3. Github 2024-03-30 Rust开源项目日报 Top10

    2024-04-02 17:12:03       39 阅读
  4. Kafka安装

    2024-04-02 17:12:03       39 阅读
  5. Rust---复合数据类型之字符串(1)

    2024-04-02 17:12:03       40 阅读
  6. LeetCode题练习与总结:最大子数组和

    2024-04-02 17:12:03       46 阅读
  7. 微信的个人号接口

    2024-04-02 17:12:03       46 阅读
  8. C++---linux运行

    2024-04-02 17:12:03       36 阅读