在线提交: https://leetcode-cn.com/problems/third-maximum-number
给定一个非空数组,返回此数组中第三大的数。如果不存在,则返回数组中最大的数。要求算法时间复杂度必须是O(n)。
示例 1:
输入: [3, 2, 1]
输出: 1
解释: 第三大的数是 1.
示例 2:
输入: [1, 2]
输出: 2
解释: 第三大的数不存在, 所以返回最大的数 2 .
示例 3:
输入: [2, 2, 3, 1]
输出: 1
解释: 注意,要求返回第三大的数,是指第三大且唯一出现的数。
存在两个值为2的数,它们都排第二。
Easy
思路:
使用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排序了~