30 天刷题计划(五)

题目来源: LeetCode 75 30 天 JavaScript 挑战

11. 盛最多水的容器

思路

双指针,一个从数组开头,一个从数组结尾分布计算最大值

代码

ts 复制代码
function maxArea(height: number[]): number {
  let max = 0
  let p1 = 0
  let p2 = height.length - 1

  while(p1 < p2) {
    if (height[p1] < height[p2]) {
      max = Math.max(max, (p2 - p1) * height[p1])
      p1++
    } else {
      max = Math.max(max, (p2 - p1) * height[p2])
      p2--
    }
  }

  return max
};

1679. K 和数对的最大数目

思路

首先将数组排序方便计算,使用双指针,前后扫描对比 k,移动指针

代码

ts 复制代码
function maxOperations(nums: number[], k: number): number {
  let result = 0
  // 排序,方便计算
  nums = nums.sort((a, b) => a - b)
  // 左右指针
  let start = 0
  let end = nums.length - 1

  while(start < end) {
    let sum = nums[start] + nums[end]

    if (sum === k) {
      result++
      start++
      end--
    } else if (k > sum) {
      start++
    } else {
      end--
    }
  }

  return result
};

643. 子数组最大平均数 I

思路

使用滑动窗口找出最大子数组的和,子数组的和最大那么子数组的平均数也是最大。

代码

ts 复制代码
function findMaxAverage(nums: number[], k: number): number {
  let max = 0
  // 计算前 k 项子数组和
  for(let i = 0; i < k; i++) {
    max += nums[i]
  }

  let maxSum = max

  for (let i = k; i < nums.length; i++) {
    // 从头开始计算最大子数组的和
    max = max - nums[i - k] + nums[i]
    maxSum = Math.max(maxSum, max)
  }

  return maxSum / k
};

2635. 转换数组中的每个元素

代码

ts 复制代码
function map(arr: number[], fn: (n: number, i: number) => number): number[] {
  let res = []

  for(let i = 0; i < arr.length; i++) {
    res.push(fn(arr[i], i))
  }
 
  return res
};
相关推荐
一水鉴天8 分钟前
整体设计 全面梳理复盘 之39 生态工具链 到顶级表征及其完全公理化
大数据·人工智能·算法
Moonbit8 分钟前
入围名单公布|2025 MGPIC 决赛即将拉开帷幕!
后端·算法
s91236010113 分钟前
【Rust】使用lldb 调试core dump
前端·javascript·rust
沐怡旸14 分钟前
【穿越Effective C++】条款21:必须返回对象时,别妄想返回其reference——对象返回的语义与效率平衡
c++·面试
2501_9411126133 分钟前
C++与Docker集成开发
开发语言·c++·算法
前端开发呀35 分钟前
🔥 99%由 Trae AI 开发的 React KeepAlive 组件,竟然如此优雅!✨
前端·trae
不是鱼39 分钟前
Canvas学习笔记(一)
前端·javascript·canvas
智者知已应修善业1 小时前
【51单片机:两边向中间流水:即两边先点亮然后熄灭,次边的点亮再熄灭,直到最中间的两个点亮再熄灭,然后重复动作。】2023-3-4
c语言·c++·经验分享·笔记·嵌入式硬件·算法·51单片机
我有一棵树1 小时前
React 中 useRef 和 useState 的使用场景区别
前端·javascript·react.js
喵个咪1 小时前
Qt6 QML 实现DateTimePicker组件
前端·qt