稀土掘金34 游戏排名第三大的分数
问题描述
小M想要通过查看往届游戏比赛的排名来确定自己比赛的目标分数。他希望找到往届比赛中排名第三的分数,作为自己的目标。具体规则如下:
如果分数中有三个或以上不同的分数,返回其中第三大的分数。
如果不同的分数只有两个或更少,那么小M将选择最大的分数作为他的目标。
请你帮小M根据给定的分数数组计算目标分数。
测试样例
样例1:
输入:n = 3,nums = [3, 2, 1]
输出:1
样例2:
输入:n = 2,nums = [1, 2]
输出:2
样例3:
输入:n = 4,nums = [2, 2, 3, 1]
输出:1
题解:
int solution(int n, std::vector<int> nums) {
set<int> uniqueNums(nums.begin(), nums.end());
if (uniqueNums.size() < 3) return *uniqueNums.rbegin();
auto it = uniqueNums.rbegin();
it ++;
it ++;
return *it;
}
这里主要用到了set的去重和排序。set是从小到大排,所以为了拿到最大值用来 rbegin() 这个反向迭代器。因为std::set 的迭代器是双向迭代器所以没有 += -= 这种操作。
双向迭代器:只支持单步的前进和后退操作,即使用++it
或--it
。它们不支持像+=
或-=
这样的算术操作。
还有一个用法很有意思就是 set<int> uniqueNums(nums.begin(), nums.end());
可以通过给set传一个范围(vector)来创建set。同样的用法在vector也有,例如:
std::vector<int> vec(uniqueNums.begin(), uniqueNums.end());
// 现在可以使用随机访问操作
return vec[vec.size() - 3];