数据结构---栈

  

接口

public interface Stack {

    /**
     * 入栈
     *
     * @param o
     * @return
     */
    public boolean push(Object o);

    /**
     * 长度
     *
     * @return
     */
    public long getSize();

    /**
     * 出栈
     */
    public Object pop();

    /**
     * 是否为空栈
     *
     * @return
     */
    public boolean isEmpty();

}


实现 :

public class StackImpl implements Stack{

    private Note root;

    private long size;

    public long getSize() {
        return size;
    }

    public boolean isEmpty() {
        return size == 0l;
    }

    public boolean push(Object o) {
        if (!validate(o))
            throw new NullPointerException("the element can't be null");
        Note note = new Note(o);
        if (null != root) {
            note.last = root;
            root = note;
        } else {
            root = note;
        }
        size++;
        return true;
    }

    private boolean validate(Object o) {
        if (null == o)
            return false;
        return true;
    }

    public Object pop() {
         if(null!=root){
             try{
                 return root.value;
             }finally{
                 root = root.last;
                 size--;
             }
         }
         return null;
    }

    private class Note {
        
        private Note last;

        private Object value;

        private Note(Object o) {
            this.value = o;
        }
    }
   

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值