力扣3290.最高乘法得分

力扣3290.最高乘法得分

递归 + 记忆化搜索

  • 对于b数组,从右往左考虑取不取如果取 则问题变成b[0] ~ b[i-1]间找j - 1个数

    • 如果不取 ,则问题变成b[0] ~ b[i]间找j个数
    • 即dfs(i,j) = max(dfs(i-1,j) , dfs(i-1,j-1) + a[j] * b[i])
  • 边界:dfs(i,-1) = 0,dfs(-1,j>=0) = -INF

  • 终点:dfs(n-1,3);

  • 同时引入记忆化搜索,因为只要参数一致,每次的结果都一样,所以遍历过的就不用再遍历

    • 初始化成INF即可
cpp 复制代码
  class Solution {
  public:
      long long maxScore(vector<int>& a, vector<int>& b) {
          int n = b.size();
          //用vector<long long>也可以
          //需要一个一个填充
          vector<array<long long,4>> memo(n);
          for(auto &row : memo)
              ranges::fill(row,LLONG_MIN);
          auto dfs = [&](auto &&dfs,int i,int j) -> long long {
              //j == -1
              if(j < 0)
                  return 0;
              if(i < 0)  //非法
                  return LLONG_MIN / 2;
              //引用取出memo[i][j],如果没更新过,就求res的同时更新
              auto &res = memo[i][j];
              if(res == LLONG_MIN)
                  res = max(dfs(dfs,i-1,j) , dfs(dfs,i-1,j-1) + (long long)a[j] * b[i]);
              return res;
          };
          return dfs(dfs,n-1,3);
      }
  };

1:1递推

  • f[i+1][j+1] 的定义和dfs(i,j)的定义一样

    • dfs(-1,j>=0) = -INF也翻译,为f[0][j] = -INF;
cpp 复制代码
  class Solution {
  public:
      long long maxScore(vector<int>& a, vector<int>& b) {
          int n = b.size();
          vector<array<long long,5>> f(n+1);
          //初始化
          for(int j=1;j<5;j++)
              f[0][j] = LLONG_MIN / 2;
          for(int i = 0;i<n;i++)
              for(int j=0;j<4;j++)
                  f[i+1][j+1] = max(f[i][j+1],f[i][j] + (long long)a[j] * b[i]);
          return f[n][4];
      }
  };
相关推荐
Q741_1471 分钟前
每日一题 力扣 1320. 二指输入的的最小距离 动态规划 C++ 题解
c++·算法·leetcode·动态规划
wfbcg10 分钟前
每日算法练习:LeetCode 76. 最小覆盖子串 ✅
算法·leetcode·职场和发展
Wect13 分钟前
LeetCode 149. 直线上最多的点数:题解深度剖析
前端·算法·typescript
qianpeng89717 分钟前
运动声源的到达结构仿真
算法
费曼学习法21 分钟前
线段树:区间查询的"终极武器",一文看透高效范围统计
算法
wayz1128 分钟前
Day 2:线性回归原理与正则化
算法·机器学习·数据分析·回归·线性回归
QQ6765800839 分钟前
基于yolo26算法的水下目标检测图像数据集 海洋生物识别 海胆识别 海龟识别数据集 海洋生物监测与保护工作 潜水作业安全辅助系 水下环境感知第10408期
算法·目标检测·水下目标检测·海洋生物识别·海胆 海龟识别·海洋生物监测与保护工作·潜水作业安全辅助 水下环境感知
七颗糖很甜1 小时前
基于 OpenCV 的 FY2 云顶图云块追踪算法实现
人工智能·opencv·算法
__Wedream__1 小时前
NTIRE 2026 Challenge on Efficient Super-Resolution——冠军方案解读
人工智能·深度学习·算法·计算机视觉·超分辨率重建
FL16238631291 小时前
基于深度学习mediape实现人员跌倒人体姿势跌倒检测算法源码+说明文件
人工智能·深度学习·算法