数组测试题

数组测试题

测试一

编写程序,使用一维数组,模拟栈数据结构。

要求:

  1. 这个栈可以存储java中的任何引用类型的数据。

  2. 在栈中提供push方法模拟压栈。(栈满了,要有提示信息。)

  3. 在栈中提供pop方法模拟弹栈。(栈空了,也要有提示信息。)

  4. 编写测试程序,new栈对象,调用push pop方法来模拟压栈弹栈的动作。

  5. 栈默认容量为5。

    package Stack;
    
    public class MyStack {
    
        private Object[] elements ;
        //定义一个栈帧
        private int index;
        //无参构造
        public MyStack() {
            this.elements = new Object[5];
            this.index = -1;
        }
        //setter and getter
        public void setElements(Object[] elements) {
            this.elements = elements;
        }
    
        public Object[] getElements() {
            return elements;
        }
    
        public void setIndex(int index) {
            this.index = index;
        }
    
        public int getIndex() {
            return index;
        }
    
        /**
         * push方法 压栈的方法 因为压栈会加入新的元素 需要传入新的元素
         * @param obj 被压入的元素
         */
        public void push(Object obj){
            if(index >= elements.length-1){
                System.out.println("压栈失败!栈已满!");
                return;
            }
            index++;
            elements[index] = obj;
    
            //所有的System.out.println()方法执行时,如果输出引用的话,自动调用引用的toString()方法。
            System.out.println("压栈" + obj + "元素成功,栈帧指向" + index);
        }
    
        /**
         * pop方法 弹栈的方法
         */
        public void pop(){
            if(index < 0){
                System.out.println("弹栈失败!栈已空!");
                return;
            }
            System.out.println("弹栈" + elements[index] + "元素成功,");
            index--;
            System.out.println("栈帧指向" + index);
        }
    }
    
    
    package Stack;
    
    public class Test {
        public static void main(String[] args) {
    
            MyStack ms = new MyStack();
            ms.push(new Object());
            ms.push(new Object());
            ms.push(new Object());
            ms.push(new Object());
            ms.push(new Object());
            ms.push(new Object());
    
            ms.pop();
            ms.pop();
            ms.pop();
            ms.pop();
            ms.pop();
            ms.pop();
    
    
        }
    }
    
    

    输出结果为:

    ​ 压栈java.lang.Object@4554617c元素成功,栈帧指向0
    ​ 压栈java.lang.Object@74a14482元素成功,栈帧指向1
    ​ 压栈java.lang.Object@1540e19d元素成功,栈帧指向2
    ​ 压栈java.lang.Object@677327b6元素成功,栈帧指向3
    ​ 压栈java.lang.Object@14ae5a5元素成功,栈帧指向4
    ​ 压栈失败!栈已满!
    ​ 弹栈java.lang.Object@14ae5a5元素成功,
    ​ 栈帧指向3
    ​ 弹栈java.lang.Object@677327b6元素成功,
    ​ 栈帧指向2
    ​ 弹栈java.lang.Object@1540e19d元素成功,
    ​ 栈帧指向1
    ​ 弹栈java.lang.Object@74a14482元素成功,
    ​ 栈帧指向0
    ​ 弹栈java.lang.Object@4554617c元素成功,
    ​ 栈帧指向-1
    ​ 弹栈失败!栈已空!


测试二

为某个酒店编写程序:酒店管理系统。模拟订房、退房、打印所有房间状态等功能。

  1. 该系统的用户是:酒店前台。

  2. 酒店中所有的房间使用一个二维数组来模拟。

  3. 酒店中的每一个房间应该是一个java对象:Room。

  4. 每一个房间Room应该有:房间编号、房间类型、房间是否空闲。

  5. 系统应该对外提供的功能:

    可以预订房间:用户输入房间编号——订房。

    可以退房:用户输入房间编号——退房。

    可以查看所有房间的状态:用户输入某个指令可以查看所有房间的状态。

package Hotel;

public class Hotel {
    //模拟酒店的楼,酒店的房间
    private Room[][] rooms;

    //通过构造方法盖楼,一共有几层,房间类型,房间编号


    public Hotel() {
        //有三层楼 每层十个房间
        rooms = new Room[3][10];
        //创建30个Room对象 放到数组中 用二维数组的遍历去放
        for(int i = 0;i < rooms.length;i++){//
            for (int j = 0;j < rooms[i].length;j++){
                //rooms[i][j] = new Room(房间编号,房间类型,房间状态);
                //房间编号:(i+1)*100+(j+1)  房间状态:刚开始所有房间都是空闲的
                //房间类型分情况 例如 一层(i=0)单人间 二层(i=1)双人间 三层(i=2)总统套房
               if(i == 0){
                   //一层
                   rooms[i][j] = new Room((i+1)*100+(j+1),"单人间",true);
               }else if(i == 1){
                   //二层
                   rooms[i][j] = new Room((i+1)*100+(j+1),"双人间",true);
               }else if(i == 2){
                   //三层
                   rooms[i][j] = new Room((i+1)*100+(j+1),"总统套房",true);
               }
            }
        }

    }
    //打印房间状态的方法
    public void print(){
        //打印所有房间的状态就是遍历二维数组
        for(int i =0;i< rooms.length;i++){
            for(int j = 0;j <rooms[i].length;j++){
                Room room = rooms[i][j];
                //print不加ln不换行 输出会自动调用toString方法 此方法我们已经重写
                System.out.print(room);
            }
            //这里需要换行 里面的for循环负责输出一层
            System.out.println();
        }
    }

    /**
     * 预订房间
     * @param num
     */
    public void checkIn(int num){
        //订房成功应该将Room对象的状态改成false。

        //通过房间编号获取房间对象
        Room room =rooms[num / 100 - 1][num % 100 -1];
        room.setRoomState(false);
        System.out.println(num + "预订成功!");
    }

    /**
     * 退房
     * @param num
     */
    public void checkOut(int num){
        Room room =rooms[num / 100 - 1][num % 100 -1];
        room.setRoomState(true);
        System.out.println(num + "已退房!");
    }
}

package Hotel;

public class Room extends Object{
    //房间编号
    private int roomNum;
    //房间类型:标准间、单人间、双人间……
    private String roomType;
    //房间状态:是否空闲 true——空闲,可以被预订  false——占用,不能被预订
    private boolean roomState;

    //构造方法
    public Room() {
    }

    public Room(int roomNum, String roomType, boolean roomState) {
        this.roomNum = roomNum;
        this.roomType = roomType;
        this.roomState = roomState;
    }

    //setter and getter
    public int getRoomNum() {
        return roomNum;
    }

    public void setRoomNum(int roomNum) {
        this.roomNum = roomNum;
    }

    public String getRoomType() {
        return roomType;
    }

    public void setRoomType(String roomType) {
        this.roomType = roomType;
    }
    //注意这里布尔类型的get的方法是isxxx(),可以自己修改。
    public boolean isRoomState() {
        return roomState;
    }

    public void setRoomState(boolean roomState) {
        this.roomState = roomState;
    }

    public void checkIn(Room room){

    }
    public void checkOut(Room room){

    }

    //正常开发流程中应该对以下两个方法进行重写,java中规定的。

    //equals方法重写
    public boolean equals(Object obj) {
        //如果obj==空,或者不是一个房间则return false。
        if(obj == null || !(obj instanceof Room)) return false;
        //如果内存地址都一样 return true
        if(this == obj) return true;
        //强转obj
        Room room = (Room)obj;
        //房间编号相等
        //这里的this.roomNum也可以调getroomNum。当前房间编号等于传过来的房间对象的房间编号,认为是同一个房间
        return (this.roomNum ==room.getRoomNum());
    }

    //toString方法重写
    //[101,单人间,空闲]
    @Override
    public String toString() {
        return "["+roomNum+","+roomType+","+(roomState ? "空闲":"占用")+"]";
    }
}
package Hotel;

import java.util.Scanner;

public class Test {
    public static void main(String[] args) {
        Hotel hotel = new Hotel();

        System.out.println("欢迎使用酒店管理系统!");
        Scanner sc = new Scanner(System.in);
        while(true){
            System.out.println("请输入对应的功能编号:【1】查看房间列表。【2】订房。【3】退房。【0】退出系统");
            int i = sc.nextInt();
                if(i == 1) {
                    hotel.print();
                } else if(i == 2) {
                    System.out.println("请输入房间编号:");
                    int roomNo = sc.nextInt();
                    hotel.checkIn(roomNo);
                }else if(i == 3) {
                    System.out.println("请输入房间编号:");
                    int roomN = sc.nextInt();
                    hotel.checkOut(roomN);
                }else if (i == 0){
                    System.out.println("再见!欢迎下次光临!");
                    return;
                }else{
                    System.out.println("输入有误,请重写输入!");
                }
            }
        }

}

IDEA快捷键:

  • Alt + Insert : 调方法

  • Ctrl + shift +/ :块注释

  • /** +回车 : /**

    ​ *

    ​ *@param obj
    ​ */

  • 光标放在类名,长按Ctrl可查看类源码

  • Alt + 7:查看类的属性和方法

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值