用python编写猴子吃桃问题_人工智能猴子摘香蕉

用python编写猴子吃桃问题_人工智能猴子摘香蕉一个房间里,天花板上挂有一串香蕉,有一只猴子可在房间里任意活动(到处走动,推移箱子,攀登箱子等)。设房间里还有一只可被猴子移动的箱子,且猴子登上箱子时才能摘到香蕉,问猴子在某一状态下(设猴子位置为A,香蕉位置在B,箱子位置为C),如何行动可摘取到香蕉。此问题的前提是猴子只有站在箱子上才能拿到香蕉,因此,需要首先让猴子找到箱子,再找到香蕉,并将箱子搬到香蕉下面。2.1使用语义网络实现猴子摘香蕉的知识表示2.2用java实现猴子摘香蕉Monkey类:12345678910111213141516171

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

  • 背景简介/问题描述

一个房间里,天花板上挂有一串香蕉,有一只猴子可在房间里任意活动(到处走动,推移箱子,攀登箱子等)。设房间里还有一只可被猴子移动的箱子,且猴子登上箱子时才能摘到香蕉,问猴子在某一状态下(设猴子位置为A,香蕉位置在B,箱子位置为C),如何行动可摘取到香蕉。

    此问题的前提是猴子只有站在箱子上才能拿到香蕉,因此,需要首先让猴子找到箱子,再找到香蕉,并将箱子搬到香蕉下面。

  • 算法介绍

2.1 使用语义网络实现猴子摘香蕉的知识表示

用python编写猴子吃桃问题_人工智能猴子摘香蕉

2.2用java实现猴子摘香蕉

Monkey类:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

package rgznlab1;

public class monkey{

    private final String position;

    private boolean status;

    public monkey(String position){

        this.position = position;

        this.status = false;

    }

    public String getPosition() {

        return this.position;

    }

    public box move(box b,String newPosition) {

        if(this.position.equals(b.getPosition())&&!this.status) {

            System.out.println(“猴子在”+this.position+”处把箱子推到了”+newPosition);

            return new box(newPosition);

             

        }return b;

    }public void climb(box b) {

        if(this.position.equals(b.getPosition())&&!this.status) {

            this.status = true;

            System.out.println(“猴子在”+this.position+”处爬上了箱子”);

        }

    }public void pick(banana b) {

        if(this.status&&this.position.equals(b.getPosition())) {

            System.out.println(“猴子在”+this.position+”处摘到了香蕉”);

        }

    }

Box类:

1

2

3

4

5

6

7

8

9

10

package rgznlab1;

public class box{

    private final String position;

    public box(String position){

        this.position = position;

    }public String getPosition() {

        return this.position;

    }

}

Banana类:

1

2

3

4

5

6

7

8

9

10

package rgznlab1;

public class banana{

    private final String position;

    public banana(String position){

        this.position = position;

    }public String getPosition() {

        return this.position;

    }

}

Main方法:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

package rgznlab1;

import java.util.Scanner;

public class main {

    public static void main(String[] args) {

        Scanner input=new Scanner(System.in);

        System.out.println(“请输入猴子位置”);

        String p1=input.next();

        System.out.println(“请输入箱子位置”);

        String p2=input.next();

        System.out.println(“请输入香蕉位置”);

        String p3=input.next();

monkey m = new monkey(p1);

box b = new box(p2);

banana bn = new banana(p3);

System.out.println(“第一步:猴子移动到box处从”+m.getPosition()+”到”+b.getPosition());

m = new monkey(b.getPosition());

System.out.println(“第二步:猴子推动box从”+b.getPosition()+”到banana处”+bn.getPosition());

b = m.move(b, bn.getPosition());

System.out.println(“第三步:猴子爬上”+b.getPosition()+”处的box”);

m.climb(b);

System.out.println(“第四步:猴子摘到香蕉”);

m.pick(bn);

    }

}

  • 算法实现

3.1 实验结果

运行结果如图所示:

用python编写猴子吃桃问题_人工智能猴子摘香蕉

  • 讨论及结论

本次实验,我同小组成员较好地完成了猴子摘香蕉的几种不同的知识表示的实现,并且通过代码层面的实现使我对知识有了更深的了解,也更加体会到猴子摘香蕉这一典型问题的价值与意义。

参考文献

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/189413.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • linux rootfs制作_pdf镜像翻转设置

    linux rootfs制作_pdf镜像翻转设置在编译目录的osdev/pub/下找到rootfs_uclibc.tgz解压开按照上节和本节验证成功的部署这个rootfs手工制作rootfs.jffs2镜像,再烧录测试即可osdrv/pub/bin/pc/mkfs.jffs2-dosdrv/pub/rootfs_uclibc-l-e0x10000-oosdrv/pub/rootfs_uclibc_64k.jffs2注…

    2022年10月7日
    2
  • idea项目打包成war_war文件打成war包

    idea项目打包成war_war文件打成war包IntelliJIDEA将项目打包war包1、准备工作IntelliJIDEA开发工具可以正常运行的Java项目2、打包war包流程使用快捷键Ctrl+Alt+Shift+s或者鼠标点击选中项目名按F4打开ProjectStructure界面选择Artifacts,点击右边+,依次选择WebApplication:Archive和For’myP…

    2025年7月29日
    5
  • hive优化大全-一篇就够了[通俗易懂]

    hive优化大全-一篇就够了[通俗易懂]1.概述  在工作中总结Hive的常用优化手段和在工作中使用Hive出现的问题。下面开始本篇文章的优化介绍。2.介绍 首先,我们来看看Hadoop的计算框架特性,在此特性下会衍生哪些问题?数据量大不是问题,数据倾斜是个问题。jobs数比较多的作业运行效率相对比较低,比如即使有几百行的表,如果多次关联多次汇总,产生十几个jobs,耗时很长。原因是mapreduce作业初始化的时间是…

    2022年4月20日
    39
  • atm异步传输模式_atm交换机的基本功能

    atm异步传输模式_atm交换机的基本功能ATM(异步传输模式)异步传输模式,又叫信元中继。ATM采用面向连接的交换方式,它以信元为单位。每个信元长53字节。其中报头占了5字节。ATM能够比较理想地实现各种QoS,既能够支持有连接的业务,又能支持无连接的业务。是宽带ISDN(B-ISDN)技术的典范。  异步传输模式(ATM)在ATM参考模式下由一个协议集组成,用来建立一个在固定53字节的数据包(信元)流上传输所有

    2022年9月21日
    3
  • 第一范式、第二范式和第三范式「建议收藏」

    第一范式、第二范式和第三范式「建议收藏」数据库的范式概念:设计数据库是,需要遵循的一些规范,要遵循后边的范式要求,必须遵循前边的所有范式要求设计关系数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式,各种范式呈梯次规范,越高的范式数据库冗余越小目前关系型数据库有六种范式:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)、BC范式、第四范式(4NF)、第五范式(5NF)。…

    2022年5月23日
    42
  • 简单实现微信扫码支付开发

    @文末附有开发案例代码的地址微信支付开发官方地址:https://pay.weixin.qq.com/wiki/doc/api/index.html 1. appid, 微信公众账号或开放平台APP的唯一标识 2. mch_id, 微信支付系统中的商户收款账号 3. partner, 财付通平台的商户账号 4. partnerkey, 财…

    2021年11月30日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号