每日一题——LeetCode1502.判断是否能形成等差数列

方法一 排序

javascript 复制代码
var canMakeArithmeticProgression = function(arr) {
    arr.sort((a,b)=>a-b)
    let diff = arr[1]-arr[0]
    for(let i=1;i<arr.length;i++){
        if(arr[i]-arr[i-1]===diff) continue
        else return false
    }
    return true
};

消耗时间和内存情况:

方法二 数学方法

找出arr里的最大值和最小值,如果最大值等于最小值说明arr里的元素都是相同的diff=0,return true。max!= min,那么用(max-min)/ arr.length-1 可以得出等差数列的差diff

遍历arr里的没一个元素num,对于任意num,它与min的差应该是diff的倍数,并且不能出现相同的倍数,用Set集合保存倍数值,如果出现相同的倍数则return false

javascript 复制代码
var canMakeArithmeticProgression = function(arr) {
    let min=Math.min(...arr)
    let max=Math.max(...arr)
    if(min===max) return true
    if((max-min)%(arr.length-1)!=0) return false
    let diff=(max-min)/(arr.length-1)

    let set = new Set()
    for(let num of arr){
        if((num-min)%diff!=0) return false
        let mult=(num-min)/diff
        if(set.has(mult)) return false
        else set.add(mult)
    }
    return true
};

消耗时间和内存情况:

相关推荐
拉不动的猪5 分钟前
项目基础搭建时的一些基本注意点
前端·javascript·面试
独家回忆36434 分钟前
每日算法-250410
算法
袖清暮雨35 分钟前
Python刷题笔记
笔记·python·算法
Code额1 小时前
ECMAScript 6 新特性(二)
前端·javascript·ecmascript
熬夜造bug1 小时前
LeetCode Hot100 刷题笔记(1)—— 哈希、双指针、滑动窗口
笔记·leetcode·hot100
风掣长空1 小时前
八大排序——c++版
数据结构·算法·排序算法
_清浅2 小时前
JavaScript(JS进阶)
开发语言·前端·javascript·操作系统·html5
小王码农记2 小时前
vue中动态绑定ref后,获取某个具体组件实例
前端·javascript·vue.js
流星白龙2 小时前
【C++算法】50.分治_归并_翻转对
c++·算法
悲且狂3 小时前
vue辅助工具(vue系列二)
前端·javascript·vue.js