Unique Paths

问题:从起点到终点总共有多少条路径
分析:f[x,y]=f[x+1,y]+f[x,y+1],用记忆化搜索就可以解决了

class Solution {

public:

    int num[110][110];

    int dfs(int m,int n,int x,int y)

    {

        if(num[x][y]) return num[x][y];

        if(x==m-1 && y==n-1) return 1;

        if(x+1<m) num[x][y]+=dfs(m,n,x+1,y);

        if(y+1<n) num[x][y]+=dfs(m,n,x,y+1);

        return num[x][y];

    }

    int uniquePaths(int m, int n) {

        memset(num,0,sizeof(num));

        return dfs(m,n,0,0);

    }

};

  

你可能感兴趣的:(unique)