这道题目很有趣,直接用组合秒解。但是我并没有掌握什么方便解组合的函数,数字一大就不行了。
既然用dp来做,那就要用dp思想:分阶段。
我直接想到每一步所能走的最多次数来解,恰好解出来。
思路如下:
只能向右或向下移动,则最上方一行与最左边一列的值为1,并且当前位置的步数则是上边格子的 步数 与 左边格子的 步数之和。
例1:
![](https://i-blog.csdnimg.cn/blog_migrate/086459f7db7b98416c22bedc13c127d8.png)
class Solution {
public:
/*
* @param m: positive integer (1 <= m <= 100)
* @param n: positive integer (1 <= n <= 100)
* @return: An integer
*/
int a[101][101];
int uniquePaths(int m, int n) {
// write your code here
for(int i =0;i<m;i++)
a[i][0]=1;
for(int i =0;i<n;i++)
a[0][i]=1;
for(int i =1;i<m;i++)
for(int j=1;j<n;j++)
a[i][j]=a[i-1][j]+a[i][j-1];
return a[m-1][n-1];
}
};