3363. 最多可收集的水果数目

Problem: 3363. 最多可收集的水果数目

文章目录

思路

dp 三次即可,三人路线不会重合,可以只开一个数组。

解题过程

先填写对角线,然后改变遍历方式填写两种方式到达重点的 dp 表即可。

复杂度

  • 时间复杂度: O ( n 2 ) O(n ^ 2) O(n2)
  • 空间复杂度: O ( n 2 ) O(n ^ 2) O(n2)

Code

cpp 复制代码
class Solution {
public:
    int maxCollectedFruits(vector<vector<int>>& fruits) {
        int n = fruits.size();
        
        vector<vector<int>> f(n + 2, vector<int>(n + 2, 0));
        
        for (int i = 1; i < n; i++) {
            f[i][i] = f[i - 1][i - 1] + fruits[i - 1][i - 1];
        }

        for (int i = 1; i < n; i++) {

            for (int j = 0; j < min(i, n - i); j++) { // 不跨过对角线
                int x = n - j;
                f[i][x] = max({
                    f[i - 1][x], 
                    f[i - 1][x - 1], 
                    f[i - 1][x + 1]
                }) + fruits[i - 1][x - 1];
            }
        }

        for (int i = 1; i < n; i++) {

            for (int j = 0; j < min(i, n - i); j++) {
                int y = n - j;
                f[y][i] = max({
                    f[y][i - 1],
                    f[y - 1][i - 1],
                    f[y + 1][i - 1]
                }) + fruits[y - 1][i - 1];
            }
        }

        return f[n - 1][n - 1] + f[n - 1][n] + f[n][n - 1] + fruits[n - 1][n - 1];
    }
};
相关推荐
charliejohn2 小时前
计算机考研 408 数据结构 树形查找 相关概念及计算题例题
数据结构·考研
NAGNIP7 小时前
一文搞懂机器学习中的特征降维!
算法·面试
NAGNIP7 小时前
一文搞懂机器学习中的特征构造!
算法·面试
Learn Beyond Limits7 小时前
解构语义:从词向量到神经分类|Decoding Semantics: Word Vectors and Neural Classification
人工智能·算法·机器学习·ai·分类·数据挖掘·nlp
你怎么知道我是队长8 小时前
C语言---typedef
c语言·c++·算法
Qhumaing9 小时前
C++学习:【PTA】数据结构 7-1 实验7-1(最小生成树-Prim算法)
c++·学习·算法
Z1Jxxx11 小时前
01序列01序列
开发语言·c++·算法
汽车仪器仪表相关领域12 小时前
全自动化精准检测,赋能高效年检——NHD-6108全自动远、近光检测仪项目实战分享
大数据·人工智能·功能测试·算法·安全·自动化·压力测试
Doro再努力12 小时前
【数据结构08】队列实现及练习
数据结构·算法