LeetCode62不同路径

题目描述

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 "Start" )。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 "Finish" )。问总共有多少条不同的路径?

解析

当前位置的数量等于上方的数量加左边的数量。

复制代码
public int uniquePaths(int m, int n) {
        /*
        * 如果左上都存在
        * 当前位置的路径数为上的路径数加左边的路径数
        *  */
        int[][] path = new int[m][n];
        path[0][0] = 1;
        for(int i = 0; i < m; i++) {
            for(int j = 0; j < n; j++) {
                if(j - 1 >= 0) {
                    path[i][j] += path[i][j - 1];
                }
                if(i - 1 >= 0) {
                    path[i][j] += path[i - 1][j];
                }
            }
        }
        return path[m - 1][n - 1];
    }
相关推荐
金銀銅鐵15 小时前
[Java] 从 class 文件看动态代理
java·后端
C++ 老炮儿的技术栈15 小时前
两个线程对socket 进行读和写,需要加锁吗
java·服务器·网络
萍萍学习15 小时前
蓝桥杯JAVA-4
java·职场和发展·蓝桥杯
XiYang-DING15 小时前
【LeetCode】LCR 019. 验证回文串 II
算法·leetcode·职场和发展
灰色小旋风15 小时前
力扣18 四数之和(C++)
数据结构·算法·leetcode
顶点多余15 小时前
深度剖析Linux 线程概念
java·linux·jvm
噜啦噜啦嘞好15 小时前
算法篇:前缀和
数据结构·算法
重生之我是Java开发战士15 小时前
【广度优先搜索】FloodFill算法: 图像渲染,岛屿数量,岛屿的最大面积,被围绕的区域
算法·宽度优先
tankeven15 小时前
HJ147 最大 FST 距离
c++·算法