列表

详情


2190. 数组中紧跟 key 之后出现最频繁的数字

给你一个下标从 0 开始的整数数组 nums ,同时给你一个整数 key ,它在 nums 出现过。

统计 nums 数组中紧跟着 key 后面出现的不同整数 target 的出现次数。换言之,target 的出现次数为满足以下条件的 i 的数目:

请你返回出现 最多 次数的 target 。测试数据保证出现次数最多的 target 是唯一的。

 

示例 1:

输入:nums = [1,100,200,1,100], key = 1
输出:100
解释:对于 target = 100 ,在下标 1 和 4 处出现过 2 次,且都紧跟着 key 。
没有其他整数在 key 后面紧跟着出现,所以我们返回 100 。

示例 2:

输入:nums = [2,2,2,2,3], key = 2
输出:2
解释:对于 target = 2 ,在下标 1 ,2 和 3 处出现过 3 次,且都紧跟着 key 。
对于 target = 3 ,在下标 4 出出现过 1 次,且紧跟着 key 。
target = 2 是紧跟着 key 之后出现次数最多的数字,所以我们返回 2 。

 

提示:

原站题解

去查看

上次编辑到这里,代码来自缓存 点击恢复默认模板
class Solution { public: int mostFrequent(vector<int>& nums, int key) { } };

python3 解法, 执行用时: 36 ms, 内存消耗: 15 MB, 提交时间: 2022-05-31 17:36:37

class Solution:
    def mostFrequent(self, nums: List[int], key: int) -> int:
        n = len(nums)
        freq = Counter()
        for i in range(n-1):
            if nums[i] == key:
                freq[nums[i+1]] += 1
        return freq.most_common(1)[0][0]

上一题