挑战 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 实现经典的睡眠函数。

相关推荐
程序员爱钓鱼15 小时前
Go语言实战案例 — 工具开发篇:实现一个图片批量压缩工具
后端·google·go
程序员的世界你不懂16 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
索迪迈科技16 小时前
网络请求库——Axios库深度解析
前端·网络·vue.js·北京百思可瑞教育·百思可瑞教育
gnip16 小时前
JavaScript二叉树相关概念
前端
蒋星熠17 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
attitude.x17 小时前
PyTorch 动态图的灵活性与实用技巧
前端·人工智能·深度学习
β添砖java17 小时前
CSS3核心技术
前端·css·css3
ChinaRainbowSea17 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
舒一笑17 小时前
同步框架与底层消费机制解决方案梳理
后端·程序员
minh_coo17 小时前
Spring框架事件驱动架构核心注解之@EventListener
java·后端·spring·架构·intellij-idea