class Solution {
        public int uniquePaths(int m, int n) {
            int dp[][] = new int[m][n];
            int i,j,k;
            for (i = 0; i< m; i++) {
                dp[i][0] = 1;
            }
            for (i = 0; i< n; i++) {
                dp[0][i] = 1;
            }
            for (i = 1; i< m; i++) {
                for (j = 1; j< n; j++) {
                    dp[i][j] = dp[i-1][j]+dp[i][j-1];
                }
            }
            return dp[m-1][n-1];
        }
    }

 

 

【leetcode】不同路径_i++

 

 

因为只能往右、往下走,所以到达某格子的路径数等于到达它上边一个格子的路径数+到达它左边一个格子的路径数之和。

画个图就一目了然了。

 

【leetcode】不同路径_其他_02