第三大的数

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

cpp 复制代码
class Solution {
public:
    int thirdMax(vector<int>& nums) {
        
    }
};

1.排序

cpp 复制代码
class Solution {
public:
    int thirdMax(vector<int>& nums) {
        sort(nums.begin(), nums.end(), greater<int>());
//默认sort从小到大,现在从大到小排序
        for (int i = 1, diff = 1; i < nums.size(); ++i) {
            if (nums[i] != nums[i - 1] && ++diff == 3) {
//前后数字不同,diff加加看数到第几个,这里不可以diff++
                return nums[i];
            }
        }
        return nums[0];//只有一个的才会输出这个
    }
};

2.有序集合

set有序去重,默认从小到大,没有push那些,插入会变有序所以没有前插后插,只有insert,erase。。

cpp 复制代码
class Solution {
public:
    //遍历数组,同时用一个有序集合来维护数组中前三大的数。具体做法是每遍历一个数,就将其插入有序集合,若有序集合的大小超过 3,就删除集合中的最小元素。这样可以保证有序集合的大小至多为 3,且遍历结束后,若有序集合的大小为 3,其最小值就是数组中第三大的数;若有序集合的大小不足 3,那么就返回有序集合中的最大值。
    int thirdMax(vector<int>& nums) {
        set<int> s;
        for (int num : nums) {
            s.insert(num);
            if (s.size() > 3) {
                s.erase(s.begin());
            }
        }
        return s.size() == 3 ? *s.begin() : *s.rbegin();
};

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

cpp 复制代码
class Solution {
public:
    int thirdMax(vector<int>& nums) {
        // set 会自动去重 + 升序排序
        set<int> s;
        for (int num : nums) {
            s.insert(num); // 正确插入元素
        }

        // 迭代器指向 set 起始位置
        auto it = s.begin();
        
        // 元素个数 >=3:返回第 3 大的数(set升序,倒数第3个)
        if (s.size() >= 3) {
            // 移动到倒数第 3 个元素
            for (int i = 0; i < s.size() - 3; ++i) {
                it++;
            }
        }
        // 元素不足 3 个:返回最大值(最后一个元素)
        else {
            it = prev(s.end());
        }
        return *it; // 返回迭代器指向的值
        }
    
};

3.一次遍历

遍历数组,并用三个变量 a、b 和 c 来维护数组中的最大值、次大值和第三大值,以模拟方法二中的插入和删除操作。为方便编程实现,我们将其均初始化为小于数组最小值的元素,视作「无穷小」,比如 −2 63 等。

cpp 复制代码
class Solution {
public:
    int thirdMax(vector<int> &nums) {
        long a = LONG_MIN, b = LONG_MIN, c = LONG_MIN;
        for (long num : nums) {
            if (num > a) {
                c = b;
                b = a;
                a = num;
            } else if (a > num && num > b) {
                c = b;
                b = num;
            } else if (b > num && num > c) {
                c = num;
            }
        }
        return c == LONG_MIN ? a : c;
    }
};
相关推荐
cpp_25011 分钟前
P1873 [COCI 2011/2012 #5] EKO / 砍树
数据结构·c++·算法·题解·二分答案·洛谷·csp
啊哦呃咦唔鱼3 分钟前
leetcodehot100-347. 前 K 个高频元素
数据结构·算法·leetcode
玛丽莲茼蒿4 分钟前
Leetcode hot100 多数元素【简单】
算法·leetcode·职场和发展
AbandonForce5 分钟前
Map类:pair键值对|map的基本操作|operator[]
开发语言·c++·算法·leetcode
澈2076 分钟前
C++核心:封装与static静态成员实战指南
开发语言·c++·算法
田梓燊11 分钟前
力扣:146.LRU 缓存
算法·leetcode·缓存
_深海凉_17 分钟前
LeetCode热题100-杨辉三角
算法·leetcode·职场和发展
小O的算法实验室27 分钟前
2025年SEVC,面向进化计算的学习注入式优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
handler0128 分钟前
进程状态流转的本质:Linux 内核队列与底层数据结构解密
linux·运维·c语言·数据结构·c++·笔记·学习
啊我不会诶37 分钟前
2024北京市赛补题
c++·算法