576. Out of Boundary Paths
Problem statement:
There is an m by n grid with a ball. Given the start coordinate (i,j) of the ball, you can move the ball to adjacent cell or cross the grid boundary in four directions (up, down, left, right). However, you can at most move N times. Find out the number of paths to move the ball out of grid boundary. The answer may be very large, return it after mod 109 + 7.
Example 1:
Input:m = 2, n = 2, N = 2, i = 0, j = 0
Output: 6
Explanation:

Example 2:
Input:m = 1, n = 3, N = 3, i = 0, j = 1
Output: 12
Explanation:

Note:
- Once you move the ball out of boundary, you cannot move it back.
- The length and height of the grid is in range [1,50].
- N is in range [0,50].
Analysis:
This question is the last one of leetcode weekly contest 31. Initially, it is tagged with medium, and then adjusted to hard today.
They mentioned a position in a two dimension board and at most N step to move and count the numbers to get out of boundary. Obviously, DP.
My first solution:
Start from (i, j), initialize all the element in the row i and col and j compared their value with N.
Do four direction dynamic programming, however, it ignored one fact that the value of one cell can come from all four directions except boundary.
The answer is wrong.
Solution:
This solution is quite simple, we have m * n board and N step to move, it is a 3 dimension DP.
The initialization status: dp[0][0 ... m -1][0 ... n - 1] is 0. means the step is 0, all value is 0.
Current value only comes from four directions of last move or 1 if it is boundary.
DP formula is:
dp[step][row][col] = dp[step - ][row - ][col] + dp[step - ][row + ][col] + dp[step - ][row][col - ] + dp[step - ][row][col + ]
we calculate the value of this three dimension matrix and return the value of dp[N][i][j].
The time complexity is O(N * m * n), space complexity is O((N + 1) * m * n)
class Solution {
public:
    int findPaths(int m, int n, int N, int i, int j) {
        unsigned int dp[N + ][m][n] = {};
        for(int step = ; step <= N; step++){
            for(int row = ; row < m; row++){
                for(int col = ; col < n; col++){
                    // the value come from four directoion
                    // if one value comes from boundary: 1
                    //      dp[step - 1][row - 1][col]
                    //      + dp[step - 1][row + 1][col]
                    //      + dp[step - 1][row][col - 1]
                    //      + dp[step - 1][row][col + 1]
                    dp[step][row][col] =  ((row == ?        : dp[step - ][row - ][col])
                                        + (row == m - ?     : dp[step - ][row + ][col])
                                        + (col == ?         : dp[step - ][row][col - ])
                                        + (col == n - ?     : dp[step - ][row][col + ])) % ;
                }
            }
        }
        return dp[N][i][j];
    }
};
576. Out of Boundary Paths的更多相关文章
- leetcode 576. Out of Boundary Paths 、688. Knight Probability in Chessboard
		576. Out of Boundary Paths 给你一个棋盘,并放一个东西在一个起始位置,上.下.左.右移动,移动n次,一共有多少种可能移出这个棋盘 https://www.cnblogs.co ... 
- 【leetcode】576. Out of Boundary Paths
		题目如下: There is an m by n grid with a ball. Given the start coordinate (i,j) of the ball, you can mov ... 
- 【LeetCode】576. Out of Boundary Paths 解题报告(Python)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 动态规划 状态搜索 记忆化搜索 相似题目 参考资料 ... 
- leetcode 576. Out of Boundary Paths
		leetcode 576 题意大概就是在一个m*n的网格中,在坐标为[i,j]的网格上放一个物体,在规定时间N(t<=N)中,有多少种方法把物体移动出去.物体只能上下左右移动,一次移动一格,移动 ... 
- 第十一周 Leetcode 576. Out of Boundary Paths (HARD) 计数dp
		Leetcode 576 给定一个二维平面, 一个球在初始位置(i,j)每次可以转移到上下左右的一格. 问在N次转移内,有多少种路径可以转移出边境. dp[i][j][k]为 在点(i,j) 已经走了 ... 
- [LeetCode] Out of Boundary Paths 出界的路径
		There is an m by n grid with a ball. Given the start coordinate (i,j) of the ball, you can move the ... 
- [Swift]LeetCode576. 出界的路径数 | Out of Boundary Paths
		There is an m by n grid with a ball. Given the start coordinate (i,j) of the ball, you can move the ... 
- leetcode bugfree note
		463. Island Perimeterhttps://leetcode.com/problems/island-perimeter/就是逐一遍历所有的cell,用分离的cell总的的边数减去重叠的 ... 
- LeetCode All in One题解汇总(持续更新中...)
		突然很想刷刷题,LeetCode是一个不错的选择,忽略了输入输出,更好的突出了算法,省去了不少时间. dalao们发现了任何错误,或是代码无法通过,或是有更好的解法,或是有任何疑问和建议的话,可以在对 ... 
随机推荐
- (15)IO流之File
			File类用封装了一个文件夹或者文件的所有属性. File类的构造方法: File(String pathname) 指定文件或者文件夹的路径创建一个File文件 File(File parent, ... 
- ICC_lab总结——ICC_lab2:设计规划
			PS:字丑,禁止转载!!! 首先先写出大概的流程,然后是一些教材的理论知识总结,最后是进行lab2的一些流程概述. 教材的理论知识总结主要是:数字集成电路物理设计学习总结--布图规划和布局 --> ... 
- java中有符号和无符号数据类型发生转换
			package com.itheima.test01;/* * byte short int long float double 是有符号位的数 * char boolean 是无符号位的数 * 补码 ... 
- Java中static的特点
			前两天面试时被问到静态的特点,当时回答地不是很好,现在来总结一下 在了解某样东西的时候我们通常会从它是什么,为什么,和怎么样在三方面来衡量,对于java中的static,我们也这样讨论下,要明确以下几 ... 
- POP3是收邮件的协议,SMTP是发邮件的协议,IMAP是一种邮箱通信协议。
			我也是第一次接触这种服务,是因为我自己在做一个小小的自动推送天气情况到自己邮箱.所以才碰到这个的/ 看一下标题,我们可以先这样理解. POP3(Post Office Protocol - Versi ... 
- strtol函数 将字符串转换为相应进制的整数
			转自http://hi.baidu.com/qwpsmile/blog/item/9bc44efa4f41018a9f514637.html +----------------+| strt ... 
- Linux学习之sudo命令
			在学习Linux用户管理时,我们不得不需要了解一个命令,那就是sudo.sudo的作用是切换身份,以其他身份来执行命令. 那么为什么在Linux系统中我们需要来切换身份呢?原因有以下几个方面 1.养成 ... 
- 基于均值漂移的三维网格分割算法(Mean Shift)
			mean shift算法是一种强大的无参数离散数据点的聚类方法,其在图像平滑.图像分割以及目标跟踪等方面都有着广泛的应用.[Yamauchi et al. 2005]基于mean shift算法提出了 ... 
- Dashboard登录成功后 RuntimeError: Unable to create a new session key.
			openstack按照官网docs部署horizon后,使用admin账号密码登录,但网页提示未知错误. 查看/var/log/httpd/error_log 提示这个:RuntimeError: U ... 
- PMBOK 和 PRINCE2的技术不同的地方是什么
			首先,PMBOK是一个框架指导,PRINCE2是一种实现方法. PMBOK是一种建议及最佳实践的集锦.PMBOK包含项目管理的工具和技术并且是一个指导,告诉我们如何做事情,在一种环境中怎样处理问题;而 ... 
