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
};
相关推荐
Dream it possible!6 分钟前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树的最小绝对差(85_530_C++_简单)
c++·leetcode·面试
xxxxxxllllllshi8 分钟前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L11 分钟前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先
蓝胖子的多啦A梦13 分钟前
ElementUI表格错位修复技巧
前端·css·vue.js·el-table表格错位
铁手飞鹰17 分钟前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
_OP_CHEN25 分钟前
前端开发实战深度解析:(一)认识前端和 HTML 与开发环境的搭建
前端·vscode·html·web开发·前端开发
xiAo_Ju33 分钟前
iOS一个Fancy UI的Tricky实现
前端·ios
H***997635 分钟前
Vue深度学习实战
前端·javascript·vue.js
toooooop81 小时前
Vuex 中 state、mutations 和 actions 的原理和写法
前端·javascript·uni-app
y***86691 小时前
前端CSS-in-JS方案
前端·javascript·css