算法训练营day34(补), 动态规划2

//62. 不同路径

func uniquePaths(m int, n int) int {

dp := make([][]int, m)

// 行赋初始值为1

for i := range dp {

dp[i] = make([]int, n)

dp[i][0] = 1

}

// 列赋初始值为1

for j := 0; j < n; j++ {

dp[0][j] = 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]

}

//63. 不同路径 II

func uniquePathsWithObstacles(obstacleGrid [][]int) int {

m := len(obstacleGrid)

n := len(obstacleGrid[0])

//如果在起点或终点出现了障碍,直接返回0

if obstacleGrid[m-1][n-1] == 1 || obstacleGrid[0][0] == 1 {

return 0

}

dp := make([][]int, m)

for i := range dp {

dp[i] = make([]int, n)

}

// 行赋初始值为1,有障碍物停止

for i := 0; i < m && obstacleGrid[i][0] == 0; i++ {

dp[i][0] = 1

}

// 列赋初始值为1,有障碍物停止

for j := 0; j < n && obstacleGrid[0][j] == 0; j++ {

dp[0][j] = 1

}

for i := 1; i < m; i++ {

for j := 1; j < n; j++ {

//有障碍物跳过

if obstacleGrid[i][j] != 1 {

dp[i][j] = dp[i-1][j] + dp[i][j-1]

}

}

}

return dp[m-1][n-1]

}

相关推荐
xwl12123 分钟前
10.6 作业
数据结构·算法
胡小禾2 小时前
JDK17和JDK8的 G1
jvm·算法
胖咕噜的稞达鸭4 小时前
算法入门:专题攻克一---双指针(3)有效三角形的个数 查找总价格为目标值的两个商品(剑指offer题目)
算法
逻辑留白陈9 小时前
Adaboost进阶:与主流集成算法对比+工业级案例+未来方向
算法
Learn Beyond Limits9 小时前
Mean Normalization|均值归一化
人工智能·神经网络·算法·机器学习·均值算法·ai·吴恩达
天选之女wow9 小时前
【代码随想录算法训练营——Day28】贪心算法——134.加油站、135.分发糖果、860.柠檬水找零、406.根据身高重建队列
算法·leetcode·贪心算法
Gohldg9 小时前
C++算法·贪心例题讲解
c++·数学·算法·贪心算法
远远远远子9 小时前
类与对象 --1
开发语言·c++·算法
Aaplloo9 小时前
【无标题】
人工智能·算法·机器学习
西望云天10 小时前
The 2024 ICPC Asia Nanjing Regional Contest(2024南京区域赛EJKBG)
数据结构·算法·icpc