Surpass Day15——Java 数组模拟栈数据结构、酒店管理系统

本文详细介绍了如何用Java实现一个栈数据结构,并模拟栈的基本操作,如push和pop,以及在酒店管理系统中使用二维数组模拟房间和订房、退房功能。
摘要由CSDN通过智能技术生成

1.3 问题展现

2、酒店管理系统

2.1 题目要求

2.2  代码呈现

2.3 问题展现


1、数组模拟栈数据结构

===========

1.1 题目要求


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

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

3)在栈中提供pop方法模拟压栈;(栈空了,要有提示信息)

4)编写测试程序,new栈对象,调用push pop方法来模拟压栈弹栈操作;

5)假设栈的默认初始化容量是10;

1.2 代码呈现


public class Text {

public static void main(String[] args) {

//创建一个栈对象,初始化容量是10个

Stack s = new Stack();

s.push(“12345ty”);

s.push(new Object());

s.push(new Object());

s.push(new Object());

s.push(new Object());

s.pop();

s.pop();

s.pop();

s.pop();

s.pop();

s.pop();

//可以使用for循环进行压栈和弹栈

}

}

class Stack{

//存储任何引用类型数据的数组

private Object[] elements;

//有参构造方法

public Stack(Object[] elements) {

this.elements = elements;

}

//无参构造方法

public Stack() {

//一维数组动态初始化

//默认初始化容量为10

this.elements = new Object[10];

}

//栈帧(永远指向栈顶元素)

private int index=-1;

//压栈方法

public void push(Object obj){

if(this.index >= this.elements.length-1){

System.out.println(“栈内存已满,压栈失败”);

return;

}

index++;

elements[index] = obj;

System.out.println(obj + “元素,压栈成功,栈帧指向” + index);

}

//弹栈方法

public void pop(){

if(this.index <= -1) {

System.out.println(“栈内存已空,弹栈栈失败”);

}

else

System.out.println(elements[index] + “元素,弹栈成功,栈帧指向” + --index);

}

//static实例变量的get方法

public Object[] getElements() {

return elements;

}

  • 15
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值