24小时热门版块排行榜    

Znn3bq.jpeg
北京石油化工学院2026年研究生招生接收调剂公告
查看: 461  |  回复: 1

wangcl8659

金虫 (小有名气)

[交流] 【求助】食人魔过程程序

食人魔过河问题
(1)三个传教士、三个食人魔和一条船在河的左岸
(2)传教士和食人魔都能撑船,船的最大准载量为2;而且当食人魔比传教士多时,食人魔会伤害传教士
(3)寻找一种渡河方案

最好是Java语言,其他也可以。
回复此楼

» 猜你喜欢

已阅   关注TA 给TA发消息 送TA红花 TA的回帖

wangcl8659

金虫 (小有名气)

余泽成:本版不鼓励未经思考的作业求助!退还金币,关闭此帖! 2010-08-15 16:14:01
这是网上找到的程序。
鉴于本人是纯管理类学生,不懂编程,但是由于作业要求,希望关注者帮忙调试,或者提供步骤,怎么把这个程序放到JAVA中,并设置页面



启发式函数是(numOfMiss + numOfCann + boatAt - 1) / (capacity - 1);



    /**

     * 启发式搜索方案

    */

    private void solveInAStar() {



        System.out.println("现在使用启发式搜索方案";



        Transport[][][] pre = new Transport[numOfMiss + 1][numOfCann + 1][2];



        long begin = initiation();



        Queue queue = new PriorityQueue();



        queue.add(new Status(numOfMiss, numOfCann, 0, -1, 0 + calF(numOfMiss,

                numOfCann, 0)));

        pre[numOfMiss][numOfCann][0] = new Transport(-1, -1, -1);

        dp[numOfMiss][numOfCann][0] = 0;



        boolean solution = false;



        while (!queue.isEmpty()) {



            Status now = queue.remove();



            int leftMiss = now.leftMiss;

            int leftCann = now.leftCann;

            int boatAt = now.boatAt;



            // System.out.printf("%d %d %d %d\n", leftMiss, leftCann, boatAt,

            // now.cost);



            if (leftCann == 0 && leftMiss == 0) {

                int idx = 0;

                while (true) {

                    Transport t = pre[leftMiss][leftCann][boatAt];

                    if (t.a == -1)

                        break;

                    steps[idx++] = t;

                    if (t.boatAt == 0) {

                        leftMiss += t.a;

                        leftCann += t.b;

                    } else {

                        leftMiss -= t.a;

                        leftCann -= t.b;

                    }

                    boatAt = 1 - boatAt;

                }



                for (int i = 0, j = idx - 1; i < j; ++i, --j) {

                    Transport tmp = steps;

                    steps = steps[j];

                    steps[j] = tmp;

                }



                OutputAnswer(idx);



                solution = true;



                break;

            }



            int i, j;



            if (boatAt == 0) {

                for (i = 0; i <= leftMiss && i <= capacity; ++i) {

                    for (j = 0; j <= leftCann && i + j <= capacity; ++j) {

                        if (i + j != 0) {

                            if (checkValidSmaller(leftMiss - i, leftCann - j,

                                    1 - boatAt, now.cost + 1)) {

                                queue.add(new Status(leftMiss - i,

                                        leftCann - j, 1 - boatAt, -1, now.cost

                                                + 1

                                                + calF(leftMiss - i, leftCann

                                                        - j, 1 - boatAt)));

                                dp[leftMiss - i][leftCann - j][1 - boatAt] = now.cost + 1;

                                pre[leftMiss - i][leftCann - j][1 - boatAt] = new Transport(

                                        i, j, boatAt);

                            }

                        }

                    }

                }

            } else {

                int rightMiss = numOfMiss - leftMiss;

                int rightCann = numOfCann - leftCann;

                for (i = 0; i <= rightMiss && i <= capacity; ++i) {

                    for (j = 0; j <= rightCann && i + j <= capacity; ++j) {

                        if (i + j != 0) {

                            if (checkValidSmaller(leftMiss + i, leftCann + j,

                                    1 - boatAt, now.cost + 1)) {

                                queue.add(new Status(leftMiss + i,

                                        leftCann + j, 1 - boatAt, -1, now.cost

                                                + 1

                                                + calF(leftMiss + i, leftCann

                                                        + j, 1 - boatAt)));

                                dp[leftMiss + i][leftCann + j][1 - boatAt] = now.cost + 1;

                                pre[leftMiss + i][leftCann + j][1 - boatAt] = new Transport(

                                        i, j, boatAt);

                            }

                        }

                    }

                }

            }

        }

        if (!solution)

            System.out.println("不存在解!";



        queue.clear();



        System.out.println("Time elapsed: "

                + (System.currentTimeMillis() - begin) + " minisecs.\n";



    }



    private int calF(int numOfMiss, int numOfCann, int boatAt) {

        return (numOfMiss + numOfCann + boatAt - 1) / (capacity - 1);

}
2楼2010-08-15 13:44:38
已阅   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 wangcl8659 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿华东理工085601材料工程303分求调剂 +12 a1708 2026-04-06 12/600 2026-04-08 13:32 by Ivanka Loong
[考研] 281求调剂 +10 椰子蘑菇 2026-04-06 10/500 2026-04-08 11:43 by zzucheup
[考研] 326分,一志愿沪9,求生物学调剂 +4 刘墨墨 2026-04-05 4/200 2026-04-08 06:22 by lijunpoly
[考研] 一志愿211,化学学硕,310分,本科重点双非,求调剂 +9 努力奋斗112 2026-04-07 9/450 2026-04-07 23:21 by JourneyLucky
[考博] 博士申请 +3 IQwQl 2026-04-05 3/150 2026-04-07 20:31 by greychen00
[考研] 材料考研求调剂总分280 +23 mkjlz1 2026-04-06 26/1300 2026-04-07 15:58 by 啊俊!
[考研] 一志愿南京航空航天大学 材料与化工329分求调剂 +9 Mr. Z 2026-04-05 9/450 2026-04-07 15:30 by 尽舜尧1
[考研] 一志愿上海海洋大学083200食品学硕,求调剂,接受其他专业 +9 what张 2026-04-01 11/550 2026-04-07 09:45 by momo皓
[考研] 372求调剂 +4 jj涌77 2026-04-02 4/200 2026-04-07 09:31 by 白云朵朵飞
[考研] 机械专硕274求调剂,不挑专业学校 +6 泛泛2333 2026-04-05 8/400 2026-04-06 18:06 by 泛泛2333
[考研] 材料专硕(0856) 339分求调剂 +10 哈哈哈鹅哈哈哈 2026-04-04 10/500 2026-04-05 18:51 by 蓝云思雨
[考研] 08专硕275调剂 +5 AaAa7420 2026-04-05 5/250 2026-04-05 18:01 by jkddd
[考研] 考研调剂 +3 mcbbc 2026-04-04 3/150 2026-04-05 10:03 by barlinike
[考研] 调剂 +9 19945159693 2026-04-03 10/500 2026-04-04 20:16 by dongzh2009
[考研] 298求调剂 +5 zzz,,r 2026-04-02 8/400 2026-04-04 19:55 by 蓝云思雨
[考研] 278求调剂 +6 Yy7400 2026-04-03 6/300 2026-04-04 09:53 by zhangdingwa
[考研] 考研调剂 +8 不爱喝饮料 2026-04-03 8/400 2026-04-03 16:40 by Mistake-J
[考研] 315求调剂 +6 顺理成张 2026-04-03 8/400 2026-04-03 14:04 by 百灵童888
[考研] 260求调剂 +3 朱芷琳 2026-04-02 3/150 2026-04-03 08:44 by yulian1987
[考研] 【求调剂】新能源材料本科,一志愿211,初试321 +6 求调剂学校, 2026-04-02 6/300 2026-04-02 09:41 by 晴空210210
信息提示
请填处理意见