广搜 ---农夫、狼、菜、羊过河问题

问题不再赘述。

四个的状态都各有两种,实质上是求【0 0 0 0】到【1 1 1 1】的最短路径。

以现在的理解,广搜就是要将起点到终点的所有路径一一枚举,从而找到最优解。队列是完美契合广搜的数据结构,将初始节点入队,然后将此节点能到达的所有符合要求且不重复的状态入队,然后初始节点出队,直到找到末节点或者队列为空(无解)。

具体实施:首先判断与农夫在同侧的,【STATUS】(STATUS表示此时状态)&【1 0 0 0】(判断向量)即可得到农夫的位置(bool0或1),同理得到其他的位置,循环判断,如果位于同侧(bool相当)且满足食物链关系,且新STATUS没有加入过队列,则加入。新STATUS用原STATUS和    循环条件中的两个判断向量的或运算   做异或运算(目的是改变这两个位状态且让其他状态不变)。(用于判断某个状态是否在队列中的数组,在进入队列后值变为上个状态)直到队列空或者找到【1 1 1 1】

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
根据引用和引用的信息,我们可以解决这个问题。假设羊用G表示,用W表示,农夫用F表示,白用C表示。初始状态为GGFF和C,目标状态是FF和CGG。 以下是一种可能的解决方案: 1. 农夫带着一只羊过,然后返回。状态变为FG和CGGF。 2. 农夫带着一只,然后带着另一只羊返回。状态变为FF和CGGW。 3. 农夫带着一只羊过,然后返回。状态变为FG和CGGWF。 4. 农夫带着一只羊过,然后带着另一只羊返回。状态变为FF和CGGWW。 5. 农夫带着一只羊过,然后返回。状态变为FG和CGGWWF。 6. 农夫带着一只羊过,然后带着一只返回。状态变为FF和CGGWWFG。 因此,羊、农夫的次数为6次。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [C语言农夫实验报告.doc](https://download.csdn.net/download/AII_IIA/12144130)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [华为OD机试用Python实现 -【羊过 or 羊、农夫】(2023-Q1 新题)](https://blog.csdn.net/hihell/article/details/129216698)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值