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];
    }
};
相关推荐
澈2072 分钟前
深度优先遍历DFS:从入门到精通
算法·深度优先
计算机安禾4 分钟前
【数据结构与算法】第45篇:跳跃表(Skip List)
c语言·数据结构·算法·list·排序算法·图论·visual studio
cmpxr_6 分钟前
【算法】ECC验签名
单片机·算法
MRDONG16 分钟前
深入理解 RAG(Retrieval-Augmented Generation):原理、工程体系与实践指南
人工智能·算法·语言模型·自然语言处理
别或许14 分钟前
线代中为什么左乘一个列满秩矩阵,不改变矩阵的秩?
人工智能·算法·矩阵
wangbing112516 分钟前
适配md5老算法
算法
Dev7z20 分钟前
基于改进YOLO11算法的芯片微缺陷检测系统(UI界面+数据集+分析界面+处置建议+训练代码)
算法·芯片制造·yolo11
papership22 分钟前
【入门级-算法-4、算法策略:差分】
数据结构·算法
Dfreedom.26 分钟前
异常检测算法详解:从“何为异常”到“如何发现”
人工智能·算法·机器学习·聚类·异常检测