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];
    }
相关推荐
w1225h18 小时前
【SpringBoot】Spring Boot 项目的打包配置
java·spring boot·后端
李少兄18 小时前
解析 IntelliJ IDEA “Immutable object is modified”警告
java·ide·intellij-idea
客卿12318 小时前
二叉树的层序遍历--思路===bfs的应用,以及java中队列的方法实操
java·算法·宽度优先
健康平安的活着18 小时前
java中事务@Transaction的正确使用和触发回滚机制【经典】
java·开发语言
Han.miracle18 小时前
IntelliJ IDEA 高效开发实用技巧
java·ide·intellij-idea
Barkamin18 小时前
使用PriorityQueue创建大小堆,解决TOPK问题
java·开发语言
gaozhiyong081318 小时前
【Spring Boot】 SpringBoot自动装配-Condition
java·spring boot·后端
寻寻觅觅☆18 小时前
东华OJ-进阶题-12-时间转换(C++)
开发语言·c++·算法
ok_hahaha18 小时前
java-从头开始-苍穹外卖-day08提交订单
java
予枫的编程笔记18 小时前
【面试专栏|Java并发编程】Java 原子类全解:AtomicInteger、LongAdder 原理与适用场景
java·并发编程·java并发·面试干货·java原子类·atomicinteger·longadder