LintCode不同的路徑

一:
有一個(gè)機(jī)器人的位于一個(gè)M×N個(gè)網(wǎng)格左上角(下圖中標(biāo)記為'Start')。
機(jī)器人每一時(shí)刻只能向下或者向右移動(dòng)一步。機(jī)器人試圖達(dá)到網(wǎng)格的右下角(下圖中標(biāo)記為'Finish')。
問(wèn)有多少條不同的路徑?

1,1 1,2 1,3 1,4 1,5 1,6 1,7
2,1
3,1 3,7
public class Solution {
    /**
     * @param n, m: positive integer (1 <= n ,m <= 100)
     * @return an integer
     */
   public int uniquePaths(int m, int n) {
        if(m == 0 || n == 0)
            return 0;
        int[][] paths = new int[m][n];
        for (int i = 0; i < m; i++) {
            paths[i][0] = 1;
        }

        for (int i = 0; i < n; i++) {
            paths[0][i] = 1;
        }

        for (int i = 1; i < m; i++) {
            for (int j = 1; j < n; j++) {
                paths[i][j] = paths[i - 1][j] + paths[i][j - 1];
            }
        }
        return paths[m - 1][n - 1];
    }
}

二:
"不同的路徑" 的跟進(jìn)問(wèn)題:

現(xiàn)在考慮網(wǎng)格中有障礙物,那樣將會(huì)有多少條不同的路徑?

網(wǎng)格中的障礙和空位置分別用 1 和 0 來(lái)表示。
樣例
如下所示在3x3的網(wǎng)格中有一個(gè)障礙物:

[
[0,0,0],
[0,1,0],
[0,0,0]
]
一共有2條不同的路徑從左上角到右下角。

注意
m 和 n 均不超過(guò)100

public class Solution {
    /**
     * @param obstacleGrid: A list of lists of integers
     * @return: An integer
     */
  public int uniquePathsWithObstacles(int[][] obstacleGrid) {
        if (null == obstacleGrid)
            return 0;
        int[] columns = obstacleGrid[0];
        int[][] paths = new int[obstacleGrid.length][columns.length];
        boolean havePath = true;
        for (int i = 0; i < obstacleGrid.length; i++) {
            if (!havePath) {
                paths[i][0] = 0;
                continue;
            }
            if (obstacleGrid[i][0] == 1) {
                paths[i][0] = 0;
                havePath = false;
            } else {
                paths[i][0] = 1;
            }
        }

        havePath = true;
        for (int i = 0; i < columns.length; i++) {
            if (!havePath) {
                paths[0][i] = 0;
                continue;
            }
            if (obstacleGrid[0][i] == 1) {
                paths[0][i] = 0;
                havePath = false;
            } else {
                paths[0][i] = 1;
            }
        }

        for (int i = 1; i < obstacleGrid.length; i++) {
            for(int j = 1;j < columns.length;j++)
            {
                if(obstacleGrid[i][j] == 1)
                {
                    paths[i][j] = 0;
                    continue;
                }
                else    
                {
                    paths[i][j] = paths[i - 1][j] + paths[i][j - 1];
                }
            }
        }
        return paths[obstacleGrid.length - 1][columns.length - 1];
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 題目 有一個(gè)機(jī)器人的位于一個(gè)M×N個(gè)網(wǎng)格左上角(下圖中標(biāo)記為'Start')。機(jī)器人每一時(shí)刻只能向下或者向右移動(dòng)一...
    六尺帳篷閱讀 737評(píng)論 0 3
  • 題目 "不同的路徑" 的跟進(jìn)問(wèn)題:現(xiàn)在考慮網(wǎng)格中有障礙物,那樣將會(huì)有多少條不同的路徑?網(wǎng)格中的障礙和空位置分別用 ...
    六尺帳篷閱讀 572評(píng)論 0 1
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,869評(píng)論 18 139
  • 在很多商品在銷售過(guò)程中 會(huì)有很多不同的價(jià)格 中 高 低 不明白商業(yè)套路的人 可能會(huì)以為是為了讓顧客有更多的選擇權(quán) ...
    繆青霞閱讀 329評(píng)論 0 0
  • pip安裝 下載get-pip.py 執(zhí)行python get-pip.py 使用參數(shù)--no-setuptool...
    tf_dejs閱讀 200評(píng)論 0 0