商人渡河问题(MATLAB版)

更新于 2020.08.03

一、问题描述

  3 名商人各带 1 名随从过河(从西岸到东岸),一只小船最多能容纳 2 人。随从们约定:在河的任意一岸,若随从人数多于商人人数,就杀人越货. 但商人们知道了他们的约定,并且掌握着过河大权,他们该采取怎样的策略才能安全过河?

二、算法思想

  这个问题实际上是一个迷宫问题,为什么这样说呢?请听我慢慢道来.
  首先,我们将每次渡河前西岸的人员分布和船所在的位置统称为一个"状态",用 [ u , v , 1 / 0 ] \small [u,v,1/0] [u,v,1/0] 表示,其中 u , v u,v u,v 表示商人、随从在西岸的人数,末分量表示船的位置:1 表示船在西岸,0 表示船在东岸.将符合条件的状态挑出来组成允许状态集合.
  其次,船最多可容纳两个人. 将渡河方案用 [ u , v ] \small [u,v] [u,v] 表示,其中 u , v u,v u,v 分别表示上船的商人数和随从数,并将其称为决策变量,决策变量构成的集合称为决策变量集合.

  共有 20 种允许状态和 5 个决策变量.
  初始状态 [ 3 , 3 , 1 ] \small [3,3,1] [3,3,1]:3 名商人、3 名随从在西岸,船停靠在西岸;
  终止状态 [ 0 , 0 , 0 ] \small [0,0,0] [0,0,0]:0 名商人、0 名随从在西岸,船停靠在东岸,此时商人和随从全部到达东岸,这样就确定了"迷宫"的入口和出口.

  从一个状态变换到另一个状态是通过决策变量实现的,这里的决策变量也就相当于"迷宫"中的一段路.
  所以,我们的任务就是选择可行的路径,从"迷宫"的入口走到出口.

  现在你应该觉得这好像是个迷宫问题,但心中应当还存有怀疑,因为只有入口和出口的话,并不能称得上是迷宫问题,那还有什么其他的特点呢?

  想想我们是怎样解决迷宫问题的?从入口出发,沿某一方向前进,若能走通,则继续往前走;如果不能走通或是有某一分叉可以抵达出口,则沿原路退回到刚刚的分叉点,换个方向继续前进. 重复这个过程,直至探索出所有可能的通路.

  这个问题也是这样的,从初始状态开始,尝试某种渡河方案,若能到达未经过的允许状态,则采取该渡河方案;如果不能到达任何一种允许状态或者是能够抵达终止状态,则原路返回至刚刚的状态,尝试其他的渡河方案. 重复这个过程,直到探索出所有的渡河方案.

  读到这儿,你可能会感觉到,这真的就是一个迷宫问题. 好,既然你认同了,咱就继续往下说.

<

  • 64
    点赞
  • 180
    收藏
    觉得还不错? 一键收藏
  • 22
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值