传教士与野人问题(完整状态搜索图)

传教士与野人问题

传教士和野人问题。三个传教士和三个野人在河的一岸, 有一条能载一个人或者两个
人的船。请设法使所有人都渡到河的另一岸, 要求在任何地方野人数都不能多于传教
士的人数。这个问题在AI 领域中很有名, 是因为它是第一个从分析的观点探讨问题。

对问题作如下抽象,以列表state=[c,a,b]分别代表初始岸边的传教士人数,野人人数,船只数目,有

  • 初始状态:state=[3,3,1]

  • agent所有可能行动:

    • b==1时,在以下五种状态中选择一种执行,

      • a=a-1,c=c-1,b=0
      • a=a-2,b=0
      • c=c-2,b=0
      • a=a-1,b=0
      • c=c-1,b=0

      但是需保证执行动作state处于状态空间之中,否则不能执行。

    • b==0时,,在以下五种状态中选择一种执行

      • a=a+1,c=c+1,b=1
      • a=a+2,b=1
      • c=c+2,b=1
      • a=a+1,b=1
      • c=c+1,b=1

      但是需保证执行动作state处于状态空间之中,否则不能执行。

    • 状态空间:
      [3,3,1],[3,2,1],[3,1,1],[3,0,1],[2,2,1],[1,1,1],[0,3,1],[0,2,1],[0,1,1]
      [0,0,0],[3,2,0],[3,1,0],[3,0,0],[2,2,0],[1,1,0],[0,3,0],[0,2,0],[0,1,0]

搜索树

在这里插入图片描述

代码实现

参考此博客

  • 28
    点赞
  • 173
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值