C#版 - Leetcode 414. Third Maximum Number题解

时间:2023-12-25 17:40:43

版权声明: 本文为博主Bravo Yeung(知乎UserName同名)的原创文章,欲转载请先私信获博主允许,转载时请附上网址

http://blog.csdn.net/lzuacm

C#版 - Leetcode 414. Third Maximum Number题解

在线提交: https://leetcode-cn.com/problems/third-maximum-number

题目描述

414. 第三大的数


给定一个非空数组,返回此数组中第三大的数。如果不存在,则返回数组中最大的数。要求算法时间复杂度必须是O(n)。

示例 1:

输入: [3, 2, 1]

输出: 1

解释: 第三大的数是 1.

示例 2:

输入: [1, 2]

输出: 2

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

示例 3:

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

输出: 1

解释: 注意,要求返回第三大的数,是指第三大且唯一出现的数。
存在两个值为2的数,它们都排第二。

思路:

使用Dictionary<int, int>存储每一个整数出现的次数,借用list对dict进行排序,然后从里面挑出第3大的KeyValuePair的Key值(出现次数为1不是必须的,不要被case 3误导)。

已AC的代码:

public class Solution
{
    public int ThirdMax(int[] nums)
    {
        int res = 0;
        Dictionary<int, int> dict = new Dictionary<int, int>();
        foreach (var num in nums)
        {
            if (!dict.ContainsKey(num))
                dict.Add(num, 1);
            else dict[num]++;
        }
        var list = dict.ToList();
        list.Sort((x, y) => -x.Key.CompareTo(y.Key));

        if (list.Count > 2)
            res = list.ElementAtOrDefault(2).Key;
        else
        {
            res = list.First().Key;
        }

        return res;
    }
}

Rank:

You are here!

Your runtime beats 97.53 % of csharp submissions.

ps: 刚开始使用Dictionary的dict.OrderByDescending(kv => kv.Key); 排序并没成功,后来只好使用list的sort排序了~