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

//62. 不同路径

func uniquePaths(m int, n int) int {

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

// 行赋初始值为1

for i := range dp {

dpi = make(\[\]int, n)

dpi0 = 1

}

// 列赋初始值为1

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

dp0j = 1

}

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

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

dpij = dpi-1j + dpij-1

}

}

return dpm-1n-1

}

//63. 不同路径 II

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

m := len(obstacleGrid)

n := len(obstacleGrid0)

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

if obstacleGridm-1n-1 == 1 || obstacleGrid00 == 1 {

return 0

}

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

for i := range dp {

dpi = make(\[\]int, n)

}

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

for i := 0; i < m && obstacleGridi0 == 0; i++ {

dpi0 = 1

}

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

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

dp0j = 1

}

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

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

//有障碍物跳过

if obstacleGridij != 1 {

dpij = dpi-1j + dpij-1

}

}

}

return dpm-1n-1

}

相关推荐
jidaowansui20 小时前
P11375 [GESP202412 六级] 树上游走
数据结构·算法
hai31524754321 小时前
FlashAttention C语言(C++)实现(展示版)
c语言·开发语言·c++·人工智能·算法
林爷万福21 小时前
光谱数据预处理:基线校正、平滑去噪实战
人工智能·算法
8Qi81 天前
LeetCode 1049:最后一块石头的重量 II —— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
wubba lubba dub dub7501 天前
第四十九周学习周报
人工智能·算法·机器学习
Java_2017_csdn1 天前
ComplexKeysShardingAlgorithm 小结
java·大数据·算法
海梨花1 天前
快手面试高频算法题
java·算法·面试
lqqjuly1 天前
超分辨率算法深度解析(Super-Resolution Algorithms)
算法
唐青枫1 天前
别再把 make 和 new 搞混:Go make 从切片到通道实战详解
go
嵌入式老牛1 天前
液晶段码(米/日字格)识别—倾斜校正
opencv·算法·仿射变换