编写Java程序
要求: 1、这个栈可以存储java中的任何引用类型的数据。 2、在栈中提供push方法模拟压栈。(栈满了,要有提示信息。) 3、在栈中提供pop方法模拟弹栈。(栈空了,也有有提示信息。) 4、编写测试程序,new栈对象,调用push pop方法来模拟压栈弹栈的动作。 5.假设栈的默认初始化为10. public class MyStack{ // 栈类 // 提供一个数组来存储栈中的元素 Object[] elements; // 栈帧(永远指向栈顶部的元素) // 每加1个元素,栈帧+1 // 每减1个元素,栈帧-1 int index; // 构造方法 // 构造方法是不是应该给一维数组一个初始化容量。 // push方法(push方法压栈) // 压栈表示栈中多一个元素。 // 但是栈如果已满,压栈失败。 // 这个方法的参数以及返回值类型自己定义。 // pop方法(pop方法弹栈) // 弹栈表示栈中少一个元素。 // 但是栈如果已空,弹栈失败。 // 这个方法的参数以及返回值类型自己定义。 }
栈类:
// 栈类 public class MyStack { // 提供一个数组来存储栈中的元素 private Object[] elements; //栈帧 private int index; /* 无参构造方法,初始化一维数组和栈帧。 */ public MyStack() { //默认初始化容量为10.(一维数组动态初始化。) this.elements = new Object[10]; //初始化index this.index = -1; } /* 压栈方法,ele为被压入的元素。 */ public void push(Object ele) { //栈帧指向数组最后一个元素的后面。 if (index >= elements.length - 1) { System.out.println("对不起,压栈失败,栈已满"); return; } //向栈中加一个元素,栈帧向上移动一个位置 // index++; // this.elements[index]=ele; this.elements[++index] = ele; System.out.println("压栈" + ele + "成功,栈帧指向:" + index); } /* 弹栈方法,从数组中弹出元素 */ public void pop() { if (index < 0) { System.out.println("弹栈失败,栈已空"); return ; } //从栈中弹出一个元素,栈帧向下移动一位。 //System.out.print("谈栈" + elements[index] + "成功"); //index-- System.out.print("谈栈" + elements[index--] + "成功"); System.out.println("栈帧指向:"+index); } public Object[] getElements() { return elements; } public void setElements(Object[] elements) { this.elements = elements; } }
测试类:
public class Text { public static void main(String[] args) { MyStack myStack=new MyStack(); for(int i=0;i<10;i++) { myStack.push(i); } System.out.println("------------------------------------------------"); for(int i=10;i>-1;i--){ myStack.pop(); } } }
运行结果:
压栈0成功,栈帧指向:0 压栈1成功,栈帧指向:1 压栈2成功,栈帧指向:2 压栈3成功,栈帧指向:3 压栈4成功,栈帧指向:4 压栈5成功,栈帧指向:5 压栈6成功,栈帧指向:6 压栈7成功,栈帧指向:7 压栈8成功,栈帧指向:8 压栈9成功,栈帧指向:9 ------------------------------------------------ 谈栈9成功栈帧指向:8 谈栈8成功栈帧指向:7 谈栈7成功栈帧指向:6 谈栈6成功栈帧指向:5 谈栈5成功栈帧指向:4 谈栈4成功栈帧指向:3 谈栈3成功栈帧指向:2 谈栈2成功栈帧指向:1 谈栈1成功栈帧指向:0 谈栈0成功栈帧指向:-1 弹栈失败,栈已空 Process finished with exit code 0