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];
    }
相关推荐
sxhcwgcy3 分钟前
快速在本地运行SpringBoot项目的流程介绍
java·spring boot·后端
进击的荆棘6 分钟前
优选算法——分治
数据结构·算法·leetcode·分治
xiaomo22497 分钟前
javaee-多线程进阶
java·开发语言
我真会写代码8 分钟前
线程池高频面试题(整理版)
java·线程池
Yupureki9 分钟前
《实战项目-个人在线OJ平台》1.项目简介和演示
c语言·数据结构·c++·sql·算法·性能优化·html5
m0_5793936616 分钟前
C++代码混淆与保护
开发语言·c++·算法
qq_1481153717 分钟前
C++中的享元模式实战
开发语言·c++·算法
左左右右左右摇晃21 分钟前
Java并发——线程间的通信
java·开发语言
Yzzz-F23 分钟前
Problem - D2 - Codeforces
算法
烟花巷子23 分钟前
C++中的解释器模式
开发语言·c++·算法