30天刷题挑战(二十二)

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

198. 打家劫舍

思路

动态规划,每次求出跟上一步比较大的值,最后返回较大值。

代码

js 复制代码
/**
 * @param {number[]} nums
 * @return {number}
 */
var rob = function(nums) {
  if (!nums.length) {
    return 0
  }

  let prev = 0
  let curr = 0

  for (let i = 0; i < nums.length; i++) {
    let temp = Math.max(curr, nums[i] + prev)
    prev = curr
    curr = temp
  }

  return curr
};

790. 多米诺和托米诺平铺

思路

动态规划,每次需要处理 4 种状态

  1. 一个正方形都没有被覆盖,记为状态 0
  2. 只有上方的正方形被覆盖,记为状态 1
  3. 只有下方的正方形被覆盖,记为状态 2
  4. 上下两个正方形都被覆盖,记为状态 3 返回 dp[n] 的值

代码

js 复制代码
/**
 * @param {number} n
 * @return {number}
 */
var numTilings = function(n) {
  let M = 1e9 + 7
  let dp = [1, 0, 0, 1]

  for (let i = 2; i <= n; i++) {
    const d0 = dp[3]
    const d1 = (dp[0] + dp[2]) % M
    const d2 = (dp[0] + dp[1]) % M
    const d3 = (dp[0] + dp[1] + dp[2] + dp[3]) % M

    dp = [d0, d1, d2, d3]
  }
  
  return dp[3]
};

62. 不同路径

思路

动态规划,从左上走到右下的方法等于,从右边开始走的路径总数加上从下边走的路径总数,动态方程为 dp[i][j] = dp[i-1][j]+dp[i][j-1]。初始化数组,每次计算当前瓷砖数的走法,返回 dp[n - 1]

代码

js 复制代码
/**
 * @param {number} m
 * @param {number} n
 * @return {number}
 */
var uniquePaths = function(m, n) {
  let dp = new Array(n).fill(1)

  for (let i = 1; i < m; i++) {
    for (let j = 1; j < n; j++) {
      dp[j] = dp[j - 1] + dp[j]
    }
  }
 
  return dp[n - 1]
};

本文完,感谢阅读。

相关推荐
老鼠只爱大米2 分钟前
LeetCode经典算法面试题 #236:二叉树的最近公共祖先(RMQ转化、Tarjan离线算法等五种实现方案详细解析)
算法·leetcode·二叉树·lca·并查集·最近公共祖先·rmq
问好眼4 分钟前
【信息学奥赛一本通】1296:开餐馆
c++·算法·动态规划·信息学奥赛
yxm26336690818 分钟前
【洛谷压缩技术续集题解】
java·开发语言·算法
张人玉27 分钟前
VisionPro Blob、条码识别、OCR 结构化速记版
人工智能·算法·机器学习·vsionpro
sleeppingfrog30 分钟前
zebra打印机实现前端打印
前端
摇滚侠35 分钟前
前端判断不等于 undefined 不等于 null 的方法
前端
愚者游世41 分钟前
力扣解决二进制&题型常用知识点梳理
c++·程序人生·算法·leetcode·职场和发展·改行学it
Geoking.1 小时前
前缀和算法:从一道 LeetCode 题看区间求和优化思想
算法·leetcode·职场和发展
爱吃rabbit的mq1 小时前
第7章 逻辑回归:二分类的基础
算法·分类·逻辑回归
DFT计算杂谈1 小时前
VASP+Wannier90 计算位移电流和二次谐波SHG
java·服务器·前端·python·算法