(nice!!!)(LeetCode 每日一题) 3363. 最多可收集的水果数目 (深度优先搜索dfs)

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


思路:深度优先搜索dfs,时间复杂度0(n^2)。

C++版本:

cpp 复制代码
class Solution {
public:
    int dfs(int i,int j,vector<vector<int>>& fruits,vector<vector<int>>& sta){
        int n=sta.size();
        // j=n-1-i就是fruits的斜对角线
        if(j>=n || j<n-1-i) return 0;
        if(i==0) return sta[i][j]=fruits[i][j];
        if(sta[i][j]!=-1) return sta[i][j];
        sta[i][j]=fruits[i][j]+max({dfs(i-1,j,fruits,sta),dfs(i-1,j-1,fruits,sta),dfs(i-1,j+1,fruits,sta)});
        return sta[i][j];
    }

    int maxCollectedFruits(vector<vector<int>>& fruits) {
        int n=fruits.size();
        int sum=0;
        // 左上角的只能走对角线
        for(int i=0;i<n;i++){
            sum+=fruits[i][i];
        }
        // sta是状态数组,避免重复递归
        vector<vector<int>> sta(n,vector<int>(n,-1));
        // 右上角的的纵坐标i不能大于横坐标j,不然就回不去,其实最后倒数第二个点就在(n-2,n-1)
        // 从(n-2,n-1)开始深度优先搜索到(0,n-1)。
        sum+=dfs(n-2,n-1,fruits,sta);
        // 左下角的情况和右上角的一样,将其按fruits的对角线翻转,按右上角的流程走一遍即可
        for(int i=0;i<n;i++){
            for(int j=0;j<i;j++){
                fruits[j][i]=fruits[i][j];
            }
        }
        sta=vector<vector<int>>(n,vector<int>(n,-1));
        sum+=dfs(n-2,n-1,fruits,sta);
        return sum;

    }
};
相关推荐
炽烈小老头3 分钟前
【 每天学习一点算法 2026/04/22】四数相加 II
学习·算法
星晨羽14 分钟前
西门子机床opc ua协议实现变量读写及NC文件上传下载
java·spring boot
alphaTao18 分钟前
LeetCode 每日一题 2026/4/20-2026/4/26
算法·leetcode·职场和发展
王璐WL1 小时前
【C++】类的默认成员函数(上)
c++
Robot_Nav1 小时前
TD3 —— 双延迟深度确定性策略梯度算法文献解读
算法·td3·drl
斯维赤1 小时前
每天学习一个小算法:归并排序
学习·算法·排序算法
王老师青少年编程1 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【区间贪心】:区间覆盖(加强版)
c++·算法·贪心·csp·信奥赛·区间贪心·区间覆盖(加强版)
无巧不成书02181 小时前
零基础Java网络编程全解:从核心概念到Socket实战,一文打通Java网络通信
java·开发语言·网络
碧海银沙音频科技研究院1 小时前
杰理项目开发大全课程
人工智能·深度学习·算法
aq55356001 小时前
Workstation神技:一键克隆调试环境
java·开发语言