商人过河问题的Java实现2

BusinessManSearch.java


//商人过河的问题
//假如有三个商人各带一个随从要过河。只有一条船得需要他们划每次只能坐两个人,条件是任何一岸的随从多于商人时随从就会抢劫商人。
//请问这三个商人怎样才能安全过河?

//算法伪代码
//初始状态<3,3,0,0>
//最终状态<0,0,3,3>
//转化的方法或者手段有<1,0><0,1><1,1>

/*
BusinessManState state
Queue toVisit

add firstState to toVisit
 
 while toVisit is not empty
     current<-first node on toVisit
     remove first node from toVisit
     if current = goal
         add current to alreadyVisited
         return true
     end if
     for each child node C of current
          add C to toVisit
     end for
     add current to alreadyVisited
  end while
*/
import java.util.ArrayList;
import java.awt.Point;
import java.util.HashMap;

public class BusinessManSearch {
 
    public void doSearch()
    {
     boolean result = false ;
     
     ArrayList toVisit = new ArrayList();
     HashMap alreadyVisit = new HashMap();
     
     //1表示由此岸驶向对岸,而2表示由对岸驶向此岸,0则什么都不表示,或者说是专门表示首节点的父节点.
     BusinessManState finalState = new BusinessManState(new Point(0,0),new Point(3,3),2);

     BusinessManState firstState = new BusinessManState(new Point(3,3),new Point(0,0),1);
     
     BusinessManState fatherState = new BusinessManState(new Point(0,0),new Point(0,0),0);
     
     ArrayList child_father= new ArrayList();
     child_father.add(firstState);
     child_father.add(fatherState);
     
     toVisit.add(child_father);
     while(!toVisit.isEmpty()&&!result)
     {
      ArrayList current = (ArrayList)toVisit.get(0);
      toVisit.remove(0);
      
   BusinessManState currentState = (BusinessManState)current.get(0);
      if(BusinessManState.equal(currentState, finalState))
      {
       String target = "&l

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值