动态规划-Cherry Pickup
2020-02-03 17:46:04
问题描述:


问题求解:
非常好的题目,和two thumb其实非常类似,但是还是有个一点区别,就是本题要求最后要到达(n - 1, n - 1),只有到达了(n - 1, n - 1)才算是有效解,two thumb是一定会有解的,所以不用加特别判断。
也是一种路径规划类的题目,难点依然是状态的表示,我们这里使用的p1,p2的坐标位置作为状态。
另外,还需要注意的是在超界的时候,我们需要返回的是Integer.MIN_VALUE,这样就可以规避掉一些中间节点到不了终点的情况。
    int[][][] dp = new int[51][51][51];
    public int cherryPickup(int[][] grid) {
        int n = grid.length;
        for (int i = 0; i <= 50; i++) {
            for (int j = 0; j <= 50; j++) {
                Arrays.fill(dp[i][j], -1);
            }
        }
        int res = dfs(grid, 0, 0, 0);
        return dp[n - 1][n - 1][n - 1] == -1 ? 0 : res;
    }
    private int dfs(int[][] grid, int x1, int y1, int x2) {
        int n = grid.length;
        int y2 = x1 + y1 - x2;
        if (x1 >= n || y1 >= n || x2 >= n || y2 >= n) return Integer.MIN_VALUE;
        if (dp[x1][y1][x2] != -1) return dp[x1][y1][x2];
        else if (x1 == n - 1 && y1 == n - 1) dp[x1][y1][x2] = grid[n - 1][n - 1];
        else if (grid[x1][y1] == -1 || grid[x2][y2] == -1) dp[x1][y1][x2] = Integer.MIN_VALUE;
        else {
            int curr = x1 == x2 && y1 == y2 ? grid[x1][y1] : grid[x1][y1] + grid[x2][y2];
            dp[x1][y1][x2] = curr + Math.max(Math.max(dfs(grid, x1 + 1, y1, x2 + 1), dfs(grid, x1 + 1, y1, x2)), Math.max(dfs(grid, x1, y1 + 1, x2 + 1), dfs(grid, x1, y1 + 1, x2)));
        }
        return dp[x1][y1][x2];
    }
动态规划-Cherry Pickup的更多相关文章
- LeetCode741. Cherry Pickup
		https://leetcode.com/problems/cherry-pickup/description/ In a N x N grid representing a field of che ... 
- [LeetCode] 741. Cherry Pickup 捡樱桃
		In a N x N grid representing a field of cherries, each cell is one of three possible integers. 0 mea ... 
- [LeetCode] Cherry Pickup 捡樱桃
		In a N x N grid representing a field of cherries, each cell is one of three possible integers. 0 mea ... 
- [Swift]LeetCode741. 摘樱桃 | Cherry Pickup
		In a N x N grid representing a field of cherries, each cell is one of three possible integers. 0 mea ... 
- 741. Cherry Pickup
		In a N x N grid representing a field of cherries, each cell is one of three possible integers. 0 mea ... 
- LeetCode 741. Cherry Pickup
		原题链接在这里:https://leetcode.com/problems/cherry-pickup/ 题目: In a N x N grid representing a field of che ... 
- 动态规划Dynamic Programming
		动态规划Dynamic Programming code教你做人:DP其实不算是一种算法,而是一种思想/思路,分阶段决策的思路 理解动态规划: 递归与动态规划的联系与区别 -> 记忆化搜索 -& ... 
- leetcode动态规划题目总结
		Hello everyone, I am a Chinese noob programmer. I have practiced questions on leetcode.com for 2 yea ... 
- 【LeetCode】动态规划(下篇共39题)
		[600] Non-negative Integers without Consecutive Ones [629] K Inverse Pairs Array [638] Shopping Offe ... 
随机推荐
- 用Python拨打电话
			用python拨打电话,先看小视频 跟selenium操作浏览器原理类似,这是用appium操作移动设备的一个自动化功能,自娱自乐,主要是通过小案例引出相关技术 一.环境配置: 1.安装 jdk 1. ... 
- ubuntu16.04安装mysql5.6
			apt-get install software-properties-commonsudo add-apt-repository 'deb http://archive.ubuntu.com/ubu ... 
- 大忙人的jdk8,比出生晚了好几个激情的夏天
			写给大忙人的jdk8到手了,第一件事情就蒙蔽了,mac装的jdk7,切换jdk的功能要整出来才行,下好jdk8up101安装,假装几行代码搞定目标在命令行下,可以通过命令'jdk6', 'jdk7', ... 
- YOLO 论文阅读
			YOLO(You Only Look Once)是一个流行的目标检测方法,和Faster RCNN等state of the art方法比起来,主打检测速度快.截止到目前为止(2017年2月初),YO ... 
- Redis(1)——5种基本数据结构
			一.Redis 简介 "Redis is an open source (BSD licensed), in-memory data structure store, used as a d ... 
- 【深入理解Java虚拟机 】类加载器的命名空间以及类的卸载
			类加载器的命名空间 每个类加载器又有一个命名空间,由其以及其父加载器组成 类加载器的命名空间的作用和影响 每个类加载器又有一个命名空间,由其以及其父加载器组成 在每个类加载器自己的命名空间中不能出现相 ... 
- pip安装psycopg2失败解决
			pip install psycopg2==2.8.4报错ERROR: Command "python setup.py egg_info" failed with error c ... 
- 解决vue2.0下IE浏览器白屏问题
			公司新开发的项目需要兼容到IE9+ 就在index.html页面加入 <meta http-equiv="X-UA-Compatible" content="IE= ... 
- 【30分钟学完】canvas动画|游戏基础(5):重力加速度与模拟摩擦力
			前言 解决运动和碰撞问题后,我们为了让运动环境更加自然,需要加入一些环境因子,比如常见的重力加速度和模拟摩擦力. 阅读本篇前请先打好前面的基础. 本人能力有限,欢迎牛人共同讨论,批评指正. 重力加速度 ... 
- 如何在普通的元素上实现enter键的绑定
			在做登录页面时候,通常当用户输入账号密码后直接按enter键就触发登录按钮了. 如果是input标签,vue中可以绑定按键修饰符,但是如果是其它标签呢.我的做法如下: document.querySe ... 
