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

  

posted @ 2014-08-02 18:30  calmound  阅读(157)  评论(0编辑  收藏  举报