(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;

    }
};
相关推荐
折哥的程序人生 · 物流技术专研5 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
一条泥憨鱼5 小时前
【Redis】数据类型和常用命令
java·数据库·redis·后端·缓存
云烟成雨TD5 小时前
Spring AI Alibaba 1.x 系列【78】沙箱(Sandbox)
java·人工智能·spring
程序员二叉5 小时前
【Java】 异常高频面试题精讲 | 易错点+对比总结
java·开发语言·面试
玖玥拾5 小时前
C/C++ 基础笔记(十四)多态与模板编程
c语言·c++·多态·模板
周航宇JoeZhou6 小时前
JB3-9-SpringAI(二)
java·ai·agent·多智能体·调度·智能体·观察
好家伙VCC6 小时前
Web Components主题热切换方案揭秘
java·前端
慕木沐6 小时前
Google ADK Java 1.0版本 核心机制与实战 Demo
java·开发语言·python
想吃火锅10056 小时前
【leetcode】14.最长公共前缀js
算法·leetcode·职场和发展
Roann_seo%6 小时前
C++文件操作完全指南:从文本读写到二进制文件处理
开发语言·c++