java 用链表实现队列,Java用链表实现队列

队列--先入先出

栈---后入先出

链表实现队列和栈。首先我们需要构建一个链表。链表有哪几要素?

1、链表本身的value

2、链表的next指针,next指针指的还是同样类型的值。

下边看代码

public class Element{

private T value;//链表值

private Elementnext;//指针

public void setNext(Elementnext) {

this.next = next;

}

public ElementgetNext(){

return next;

}

public void setValue(T value) {

this.value = value;

}

public T getValue(){

return value;

}

}

下边我们来构建先入先出的队列。

首先队列有一个头,不然的话 队列从哪开始呢?

所以我们定义类时主要包括  头、尾、链表长度。

代码如下:

public class ListImpl{

private Elementfirst=null; //链表头

private Elementlast=null; //链表尾

private int size=0; //链表长度

public boolean pushBack(T newElement) {

Elementelement=new Element<>();

element.setValue(newElement);

if(size==0) {

first=element;

size++;

return true;

}

if(last==null){

last=element;

first.setNext(last);

}else {

last.setNext(element);

last=element;

}

size++;

return true;

}

public ElementpopFront() {

if(first==null){

return null;

}else {

Elementresult=first;

first=first.getNext();

return result;

}

}

public int size() {

return size;

}

public Element front() {

return first;

}

}

好了 到底我们的链表结构就完成了。下边测试一下吧

public static void main(String[] args) {

ListImpllist=new ListImpl();

list.pushBack("11");

list.pushBack("22");

list.pushBack("33");

System.out.print(list.popFront().getValue().toString());

System.out.print(list.popFront().getValue().toString());

System.out.print(list.popFront().getValue().toString());

}

结果:11

结果:22

结果:33

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值