挑战 LeetCode JavaScript 算法[简单]

LeetCode 前端算法题

难度:简单

2619. 数组原型对象的最后一个元素

ts 复制代码
Array.prototype.last = function() {
    let len = this.length
    if(len === 0) return -1
    return this[len -1]
};

处理数组长度为0 和,最后一个数据,当然使用 this 指向当前数组。

2620. 计数器

给定一个整型参数 n,请你编写并返回一个 counter 函数。这个 counter 函数最初返回 n,每次调用它时会返回前一个值加 1 的值 ( n , n + 1 , n + 2 ,等等)。

ts 复制代码
/**
 * @param {number} n
 * @return {Function} counter
 */
var createCounter = function(n) {
    let ifInit = false; // 初始化 flat
    let res // 初始化闭包变量
    return function() {
        if (!ifInit) {
            ifInit = true
            res = n;
        } else {
            res += 1
        }
        return res
    };
};

/** 
 * const counter = createCounter(10)
 * counter() // 10
 * counter() // 11
 * counter() // 12
 */

这里有一点,要能处理 负数, 也就是不同使用 0 做假值判断。

2621. 睡眠函数

  • 接收一个正整数参数 millis ,并休眠 millis 毫秒。要求此函数可以解析任何值
  • 执行完时返回一个 Promise 对象
ts 复制代码
async function sleep(millis) {
  return new Promise((resolve) => {
    setTimeout(() => {
      resolve()
    }, millis)
  })
}

很简单使用,使用 Promise 和定时器组合即可, 当然也可以简化语法:

ts 复制代码
const sleep = (ms: number) => new Promise(resolve => setTimeout(resolve, ms))

小结

本文主要介绍了三个简单的算法题,目的是前端方向其实是算法,三个题目主要关注的点是数组的长度访问,数组原型的 this 指向,计数器中的闭包的使用方法,使用 promise + setTimeout 实现经典的睡眠函数。

相关推荐
星星在线34 分钟前
MusicFree:一个「All in One」的个人音乐服务器,让听歌回归简单
前端·后端
IT_陈寒2 小时前
Redis的SETNX并发问题让我加了三天班
前端·人工智能·后端
demo007x2 小时前
Docling 文档转换以及技术架构分析
前端·后端·程序员
京东云开发者2 小时前
京东市民服务又“上新”!这次是黑龙江“龙易办”
前端
袋鱼不重3 小时前
我的神奇同事,AI 用多了居然写了个 Open In Codex
前端·后端·ai编程
用户8356290780513 小时前
使用 Python 操作 Word 内容控件
后端·python
像我这样帅的人丶你还3 小时前
啥? 前端也要会干Java?🛵🛵🛵
后端
Hommy883 小时前
【剪映小助手】添加贴纸接口(Add Sticker)
后端·github·剪映小助手·视频剪辑自动化·剪映api
通信小呆呆3 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
Fireworks4 小时前
深入vue3源码解读 -- 1、响应式的基础概念
前端