64题:最小路径和(基础动态规划)

该博客探讨了如何解决LeetCode上的最小路径和问题,最初尝试使用递归但因超时而转向迭代解决方案。作者注意到内存使用较高,于是尝试优化,包括减少行的存储、使用队列仅保存必要的状态,但发现内存消耗反而增加。文章讨论了可能的原因,如Go切片的回收机制,并提出利用状态之间的线性关系进行迭代计算,以减少内存占用,但遗憾优化并未成功。
摘要由CSDN通过智能技术生成

给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小。
说明:每次只能向下或者向右移动一步。
地址:https://leetcode-cn.com/problems/minimum-path-sum/

最开始使用递归寻找子问题的解,提交超时。然后老老实实写了迭代,用数组存放子问题的结果以免重复计算。

func minPathSum(grid [][]int) int {
   
	min := func(a, b int) int {
   
		if a < b {
   
			return a
		} else {
   
			return b
		}
	}
	dp := make([][]int, len(grid))
	for i, _ := range dp {
   
		dp[i] = make([]int, len(grid[0]))
	}
	dp[0][0] = grid[0][0]
	if len(dp) > 1 {
   
		for i := 1; i < len(dp); i++ {
   
			dp[i][0] = grid[i][0] + dp[i-1][0]
		}
	}
	if len(dp[0]) > 1 {
   
		for j := 1; j < len(dp[0]); j++ {
   
			dp[
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值