每日一题——LeetCode961

方法一 排序法:

2*n长度的数组里面有一个元素重复了n次,那么将数组排序,求出排序后数组的中间值(因为长度是偶数,没有刚好的中间值,默认求的中间值是偏左边的那个)那么共有三种情况:

  1. 重复n次的元素为最小值那么数组前一半都是该元素,此时中间值也是该元素
  2. 重复n次的元素为最大值,那么数组后一半都是该元素,此时中间值后面一个就是该元素
  3. 既不是最大值也不是最小值,那么中间值也一定就是该元素
javascript 复制代码
var repeatedNTimes = function(nums) {
    nums.sort((a,b)=>a-b)
    var mid = Math.floor((nums.length-1)/2)
    if(nums[mid]===nums[mid-1] || nums[mid]===nums[mid+1])
        return nums[mid]
    else if(nums[mid+1]===nums[mid+2]) 
        return nums[mid+1]
};

消耗时间和内存情况:

方法二 Map集合

用map记录nums里的各元素各出现了多少次,出现了n次即可返回

javascript 复制代码
var repeatedNTimes = function(nums) {
    var len = nums.length/2
    var map = new Map()
    for(let n of nums){
        if(map.has(n)){
            map.set(n,map.get(n)+1)
            if(map.get(n)===len) return n
        }else{
            map.set(n,1)
        }
    }
};

消耗时间和内存情况:

方法三 数学方法:

考虑重复元素x在nums中出现的位置;

如果相邻的x之间至少都隔了2个位置,那么数组的总长度至少为:n+2(n-1)=3*n - 2

当n>2时,3n-2 > 2n 不存在满足要求的数组。因此一定存在两个相邻的x,它们的位置是连续的,或者只隔了1个位置

当n=2时,数组的长度最多为2n=4,因此最多只能隔2个位置。

所以我们只需要遍历所有间隔2个位置及以内的小标对,判断对应的元素是否相等即可

javascript 复制代码
var repeatedNTimes = function(nums) {
   const n = nums.length;
    for (let gap = 1; gap <= 3; ++gap) {
        for (let i = 0; i + gap < n; ++i) {
            if (nums[i] === nums[i + gap]) {
                return nums[i];
            }
        }
    }
    // 不可能的情况
    return -1;
};
相关推荐
Frank_refuel几秒前
C++STL之set和map的接口使用介绍
数据库·c++·算法
java修仙传1 分钟前
力扣hot100:跳跃游戏||
算法·leetcode·游戏
喵喵喵小鱼1 分钟前
arcgis JavaScript api实现同时展示多个撒点气泡
开发语言·javascript·arcgis
闻缺陷则喜何志丹2 分钟前
【模拟】P9670 [ICPC 2022 Jinan R] Frozen Scoreboard|普及+
c++·算法·模拟·洛谷
永远都不秃头的程序员(互关)5 分钟前
【K-Means深度探索(十一)】K-Means VS 其他聚类算法:如何选择最合适的工具?
算法·kmeans·聚类
洛生&12 分钟前
Nested Ranges Count
算法
老鼠只爱大米12 分钟前
LeetCode经典算法面试题 #142:环形链表 II(哈希表、快慢指针等多种方法详细解析)
算法·leetcode·链表·快慢指针·floyd算法·环形链表
谢尔登13 分钟前
Vue3架构设计——调度系统
前端·javascript·vue.js
数智工坊14 分钟前
【操作系统-线程介绍】
linux·算法·ubuntu
小龙报16 分钟前
【C语言进阶数据结构与算法】LeetCode27 && LeetCode88顺序表练习:1.移除元素 2.合并两个有序数组
c语言·开发语言·数据结构·c++·算法·链表·visual studio