java 数据结构之 链式存储结构 队列

package com.xdl.data_stru;

public class Day_Four_LinkQueueNode<E> {
    public  E  data;
    public  Day_Four_LinkQueueNode<E> next; 
}
package com.xdl.data_stru;

@SuppressWarnings("unused")
public class Day_Four_LinkQueue<E> {
    //队尾和队头对象化,data作为存储元素;
    private Day_Four_LinkQueueNode<E> front;
    private Day_Four_LinkQueueNode<E> rear;
    private int len;
    
    private void init() {
	this.front =null;
	this.rear =null;
    }

    private boolean  push_stack(E e) {
	Day_Four_LinkQueueNode<E> p = new Day_Four_LinkQueueNode<E>();
	if (p==null) {
	    return false;
	}else {
	    p.data =e;
	    p.next =null;
	    //如果队列为空,则赋予新的队头,反之则插入
	    if (!is_null()) {
		this.front =p;
	    }else {
		this.rear.next =p ;
	    }
	    //将插入的元素作为队尾
	    this.rear =p;
	    this.len++;
	    return true;
	}
    }
    private boolean is_null() {
	if (this.front ==null) {
	    return true;
	}
	return false;
    }
    //出队.应该先考虑释放当前的this.front ;取出的应该是 E e;
    private E out_stack() {
	Day_Four_LinkQueueNode<E> p ;
	E e;
	if (!is_null()) {
	    e=this.front.data;
	    p=this.front;
	    //重置front,若只有一个元素的时候,则初始化
	    this.front =this.front.next;
	    if (this.front ==null) {
		this.rear =null;
	    }
	    //释放原来的this.front;
	    p = null;
	    this.len--;
	    return e;
	}
	return null;
    }
    private E get_front() {
	if (!this.is_null()) {
	    return this.front.data;
	}
	return null;
    }
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天瞳月

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值