lintcode_114_不同的路径

2018-06-17 21:43:17来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

不同的路径

 

有一个机器人的位于一个 m × n 个网格左上角。

机器人每一时刻只能向下或者向右移动一步。机器人试图达到网格的右下角。

问有多少条不同的路径?

注意事项

n和m均不超过100

样例

给出 m = 3 和 n = 3, 返回 6.
给出 m = 4 和 n = 5, 返回 35.

标签
动态规划 数组
相关题目
 
 
 
这道题目很有趣,直接用组合秒解。但是我并没有掌握什么方便解组合的函数,数字一大就不行了。
既然用dp来做,那就要用dp思想:分阶段。
我直接想到每一步所能走的最多次数来解,恰好解出来。
思路如下:
          只能向右或向下移动,则最上方一行与最左边一列的值为1,并且当前位置的步数则是上边格子的 步数 与 左边格子的 步数之和。
例1:
 
 
答案为6。

 

 
 
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];
    }
};

  

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:【C++学习笔记】常见运算符重载

下一篇:洛谷P3531 [POI2012]LIT-Letters