拜访(动态规划)

该博客介绍了一个使用动态规划求解的问题,经理从某个位置出发,只能沿着两个特定方向(左下或右上)移动,目标是找到到达商家的最短路径。文章通过举例说明解题思路,解释了如何根据经理和商家的位置确定可行路径,并用代码展示了解决方案矩阵的初始化和填充过程。
摘要由CSDN通过智能技术生成

题目描述

现在有一个城市销售经理,需要从公司出发,去拜访市内的商家,已知他的位置以及商家的位置,但是由于城市道路交通的原因,他只能在左右中选择一个方向,在上下中选择一个方向,现在问他有多少种方案到达商家地址。
给定一个地图map及它的长宽n和m,其中1代表经理位置,2代表商家位置,-1代表不能经过的地区,0代表可以经过的地区,请返回方案数,保证一定存在合法路径。保证矩阵的长宽都小于等于10。

测试样例:
[[0,1,0],[2,0,0]],2,3
返回:2

解题思路:
因为题目限制了在某个位置经理只能往两个方向走,所以就经理全程只有四种可以走的走法分别为左上、左下、右上、右下。所以一开始要判断经理和商家的方向,找到其行走的方向,若商家在经理的左下方则经理全程只能向左或者向下行走。
例如经理在黄色位置,商家在蓝色位置,橘色的为不能走的位置,空白的为可以走的路径,则经理只能往左下走。
这里写图片描述
动态规划思想:
每一个位置可以走的位置可以由其左上、左下、右上、右下相加得到,当选定一个方向之后只能由该方向的相加得到,如上面的例子只能由其上方和右边两个位置可达路径相加。
所以一开始只能由经理所在的位置往商家所在的位置斜着移动,动态的获得路径和。
经理只能往下或者往走,所以其到商家的位置等于商家所在的位置的上方位置的可达路径数+商家所在的位置的右方的可到达路径数的和,即为2。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值