0062.不同路径
方法一:动态规划
时间复杂度 $O(m \times n)$,空间复杂度 $O(m \times n)$。
func uniquePaths(m int, n int) int {
dp := make([][]int, m)
for i := 0; i < m; i++ {
dp[i] = make([]int, n)
dp[i][0] = 1
}
for i := 0; i < n; i++ {
dp[0][i] = 1
}
for i := 1; i < m; i++ {
for j := 1; j < n; j++ {
dp[i][j] = dp[i-1][j] + dp[i][j-1]
}
}
return dp[m-1][n-1]
}
方法二 :数学
易知解法数目为:$C_{m+n-2}^{m-1} = \frac{(m+n-2)(m+n-3)···n}{(m-1)!}$,故时间复杂度 $O(m)$,空间复杂度 $O(1)$。
func uniquePaths(m int, n int) int {
ans := 1
for i, v := 1, n; i < m; i, v = i+1, v+1 {
ans = ans * v / i
}
return ans
}