问题:从起点到终点总共有多少条路径
分析: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); } };
原文:http://www.cnblogs.com/zsboy/p/3887315.html