Java练习数据结构第3章栈和队列——顺序栈

3.1.2 (1)顺序栈 页码P42

package hicc.ds.c02_linear2;

import java.util.Arrays;

public class SeqStack {
	private int maxSize = 10; //最大存储长度
	private Object[] data = new Object[maxSize]; //顺序栈的存储空间
	private int top; //栈顶元素的位置
	
	public SeqStack() { //初始化空栈
		top = -1;
	}
	
	public boolean emptySeqStack() { //栈空判别算法
		if (top == -1) {
			return true;
		} else {
			return false;
		}
	}
	
	public int pushSeqStack(Object x) { //入栈算法
		if (top == maxSize-1) {
			return 0;
		} else {
			top++;
			data[top] = x;
			return 1;
		}
	}
	
	public Object popSeqStack() { //出栈算法
		if(emptySeqStack()) {
			return null;
		} else {
			Object x = data[top];
			top--;
			return x;
		}
	}
	
	public void showData() { //展示栈内数据
		System.out.println(Arrays.toString(data));
		System.out.println(top);
	}
	
	public static void main(String[] args) { //测试
		SeqStack seqStack = new SeqStack();
		seqStack.pushSeqStack('A');
		seqStack.pushSeqStack('B');
		seqStack.pushSeqStack('C');
		seqStack.showData();
		Object x = seqStack.popSeqStack();
		System.out.println(x);
		seqStack.showData();
	}
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值