package other;
import java.util.Scanner;
public class MyStack {
Object[] oj = new Object[10];
static MyStack ms = new MyStack();
public void method1() {
System.out.println("请选择出栈或入栈,出栈请输入0,入栈请输入1");
Scanner s1 = new Scanner(System.in);
int i = s1.nextInt();
if(i==0) { //出栈
ms.pop();
}else if(i==1) { //入栈
System.out.println("请输入要入栈的元素");
Scanner sn = new Scanner(System.in);
Object ot = sn.next();
ms.push(ot);
}else {
System.out.println("输入有错误请重新输入");
ms.method1();
}
}
public static void main(String[] args) { //主方法
ms.method1();
}
//入栈方法
public void push(Object o) {
for(int i = 0;i<oj.length;i++) {
if(oj[i]==null) {
oj[i] = o;
System.out.print("栈内元素有:");
for(int j = 0;j<oj.length;j++) {
System.out.print(oj[j]+" ");
}
System.out.println();
ms.method1();
break;
}else if(oj[oj.length-1] != null) {
System.out.println("栈已满,请先出栈");
break;
}
}
}
//出栈方法
public void pop() {
for(int i = oj.length;i>=0;i--) {
if(oj[0] == null) {
System.out.println("栈内无元素,无法出栈");
ms.method1();
}else if(oj[i] != null) {
oj[i] = null;
for(int j = 0;j<oj.length;j++) {
System.out.print("当前栈内元素有:");
System.out.print(oj[j]+" ");
}
break;
}
}
}
}
请选择出栈或入栈,出栈请输入0,入栈请输入1
0
栈内无元素,无法出栈
请选择出栈或入栈,出栈请输入0,入栈请输入1
1
请输入要入栈的元素
5
栈内元素有:5 null null null null null null null null null
请选择出栈或入栈,出栈请输入0,入栈请输入1
0
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: Index 10 out of bounds for length 10
at other.MyStack.pop(MyStack.java:68)
at other.MyStack.method1(MyStack.java:17)
at other.MyStack.push(MyStack.java:52)
at other.MyStack.method1(MyStack.java:24)
at other.MyStack.pop(MyStack.java:66)
at other.MyStack.method1(MyStack.java:17)
at other.MyStack.main(MyStack.java:37)
出栈入栈程序,入栈正常,出栈出现异常
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 树海路伴 2021-11-28 21:34关注
for(int i = oj.length;i>=0;i--) 应该是oj.length-1
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 c语言写的8051单片机存储器mt29的模块程序
- ¥60 求直线方程 使平面上n个点在直线同侧并且距离总和最小
- ¥50 java算法,给定试题的难度数量(简单,普通,困难),和试题类型数量(单选,多选,判断),以及题库中各种类型的题有多少道,求能否随机抽题。
- ¥50 rk3588板端推理
- ¥250 opencv怎么去掉 数字0中间的斜杠。
- ¥15 这种情况的伯德图和奈奎斯特曲线怎么分析?
- ¥250 paddleocr带斜线的0很容易识别成9
- ¥15 电子档案元素采集(tiff及PDF扫描图片)
- ¥15 flink-sql-connector-rabbitmq使用
- ¥15 zynq7015,PCIE读写延时偏大