当前位置: 首页 > news >正文

JS之刷刷

实现一个函数 minBy(array, iteratee),该函数在遍历 array 后,根据 iteratee 的返回值找到最小值的元素。

这道题虽然思路很简单,就是按照应用itreratee然后排序,但是有一些细节需要注意

  • 做空值判断断言处理的时候需要将 null 和 undefined 都包含(但是这道题不做特殊处理下面也包含了)
  • 将iteratee作用在array元素上有时候会是undefined,那么就需要做判断是否纳入考虑
  • 如果最后 minIndex 还是初始的哨兵值的话,就返回 undefined
export default function minBy(array, iteratee) {// if (!array || array.length === 0) return undefined// 注意特判let min ;let mini = -1;for (let i=0;i<array.length;i++){const val = iteratee(array[i])if ( val === undefined ) continueif(mini === -1 || val<min){mini = i;min = val;}}if (mini===-1) return undefinedreturn array[mini];
}

事件循环(宏任务、微任务、渲染帧任务)

  • Promise里面的是同步代码,遇到resolve或reject放到微任务里面异步、去找then和catch
const promise = new Promise((resolve, reject) => {console.log(1)resolve()console.log(2)
})
promise.then(() => {console.log(3)
})
console.log(4)
  • 1 2 4 3

Implement a function that performs a recursive, in-place quick sort. The function should take in an array of integers. The output should be an array with the input sorted in ascending order.

快速排序

  • 三路快排:分治、归并。在每段当前区间,将小与当前 pivot (默认是左边)的值排在左边,大于的排右边,那么中间的就是确定的等于的(和插入排序一样都是将无序的分为已定的有序的以及待排的无序的),然后接着对左右两边无序的排序,最后归并(其实也不用归了,因为是直接在arr绝对索引上改的)返回 arr
export default function quickSort(arr,left=0,right=arr.length-1) {if(left>=right) return arr;let lt = left;let gt = right;let pivot = arr[left];let i = left+1;while(i<=gt){if(arr[i]<pivot){[arr[lt],arr[i]]=[arr[i],arr[lt]];lt++;i++;}else if(arr[i]>pivot){[arr[i],arr[gt]]=[arr[gt],arr[i]];gt--;}else{i++;}}quickSort(arr,left,lt-1);quickSort(arr,gt+1,right);return arr;
}

实现一个 useBoolean Hook,用于管理布尔状态,并提供额外的便捷实用方法。

写React自定义Hook管理状态(嵌套 useState 这个Hook钩子)

  • 别忘记初始化 = false
import { useState } from 'react'
export default function useBoolean(initialValue = false) {const [value, setValue] = useState(initialValue);const setTrue = () => setValue(true);const setFalse = () => setValue(false);const toggle = () => setValue(v => !v);return { value, setTrue, setFalse, toggle };
}
http://www.dtcms.com/a/358907.html

相关文章:

  • Langflow核心技术学习笔记(新)
  • LangChain.js 实战与原理:用 LCEL 构建可维护的 RAG / Agent 系统(含 4 套 30+ 行代码)
  • 揭开智能体架构面纱:90% 属软件工程,10% 为 AI 技术
  • Python数据分析:在Python中,reindex和set_index以及reset_index最本质的区别是什么?
  • B树与B+树的原理区别应用
  • Python 的 argparse 模块中,add_argument 方法的 nargs 参数
  • Ubuntu系统下交叉编译Android的X264库
  • hello算法笔记 01
  • Jedis、Lettuce、Redisson 技术选型对比
  • 下载 | Win11 23H2正式版最新原版ISO系统映像 (22631.5840、多合一版本)-修复系统问题
  • LangGraph 深度解析(二):掌握 LangGraph 函数式 API 的状态化 AI 工作流
  • openEuler2403安装部署Redis8
  • JavaScript之性能优化
  • HiFi-GAN模型代码分析
  • txt2las批量测井txt文件转las
  • 【C++】类和对象3
  • 【学Python自动化】 1. Python 安装与配置完全指南 (Windows)
  • 微论-突触的作用赋能思考(可能是下一代人工智能架构的启发式理论)
  • fastdds qos:LifespanQosPolicy
  • 2025年- H101-Lc209--1979.找出数组的最大公约数(gcd最大公约数)--Java版
  • STM32G474 IAP 双bank升级的坑
  • git的三种分区与分支的关系
  • Pomian语言处理器研发笔记(二):使用组合模式定义表示程序结构的语法树
  • for in+逻辑表达式 生成迭代对象,最后转化为列表 ——注意list是生成器转化为列表,但[生成器]得到的就是一个列表,其中包含一个生成器元素
  • HarmonyOS 持久化存储:PersistentStorage 实战指南
  • Kafka面试精讲 Day 2:Topic、Partition与Replica机制
  • Midscene.js:AI驱动的UI自动化测试框架
  • PLSQL Developer 12.0.1 x64 安装步骤详解(附Oracle连接设置|附安装包下载)​
  • SQL 学习
  • 探索 XGBoost 与 LightGBM 的差异:哪个更适合你的项目?