java中的队列 单项队列 双向队列_java 队列、优先级队列、双向队列示例演示代码...

博客主要围绕Java中的队列展开,给出了Queue实现大部分操作的基本示例,除优先队列外,Queue按元素置入顺序产生元素。还介绍了优先级队列的主要和次要优先级排序,以及双向队列,可在两端添加或移除元素,并给出了相应代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package org.rui.collection2.queues;

import java.util.LinkedList;

import java.util.PriorityQueue;

import java.util.Queue;

import java.util.concurrent.ArrayBlockingQueue;

import java.util.concurrent.ConcurrentLinkedQueue;

import java.util.concurrent.LinkedBlockingQueue;

import java.util.concurrent.PriorityBlockingQueue;

import org.rui.generics.anonymity.Generator;

/**

* 下面涉及Queue实现的大部分操作的基本示例

* 可以看到除了优先队列,Queue将精确地按照元素被置于Queue中的顺序产生它们

* @author lenovo

*

*/

public class QueueBeHavior {

private static int count=10;

static void test(Queue queue,Generator gen)

{

for(int i=0;i

{

//T temp=gen.next();

//System.out.println(temp);

queue.offer(gen.next());

}

while(queue.peek()!=null)

System.out.print(queue.remove()+" ");

System.out.println();

}

static class Gen implements Generator

{

String[] s=

("one tow three four five six seven eight nine ten".split(" "));

int i;

public String next()

{

return s[i++];

}

}

public static void main(String[] args)

{

test(new LinkedList(),new Gen());

test(new PriorityQueue(),new Gen());

test(new ArrayBlockingQueue(count),new Gen());

test(new ConcurrentLinkedQueue(),new Gen());

test(new LinkedBlockingQueue(),new Gen());

test(new PriorityBlockingQueue(),new Gen());

}

}

/**output:

one tow three four five six seven eight nine ten

eight five four nine one seven six ten three tow

one tow three four five six seven eight nine ten

one tow three four five six seven eight nine ten

one tow three four five six seven eight nine ten

eight five four nine one seven six ten three tow

*/

package org.rui.collection2.queues;

import java.util.PriorityQueue;

/**

* 优先级队列

* 主要和次要的优先级排序

* 该列表的排序顺序也是通过实现Comparable而进行控制的

* @author lenovo

*

*/

public class ToDoList extends PriorityQueue

{

static class ToDoItem implements Comparable

{

private char primary;//主要的

private int secondary;//二

private String item;

public ToDoItem(String item,char primary, int secondary)

{

this.primary = primary;

this.secondary = secondary;

this.item = item;

}

public int compareTo(ToDoItem o)

{

if(primary>o.primary)//先比较主要的

return +1;

if(primary==o.primary)

if(secondary>o.secondary) //再比较次要的

return +1;

else if(secondary==o.secondary)

return 0;

return -1;

}

public String toString()

{

return Character.toString(primary)+secondary+": "+item;

}

}

public void add(String td,char pri,int sec)

{

super.add(new ToDoItem(td, pri, sec));

}

public static void main(String[] args) {

ToDoList to=new ToDoList();

to.add("Empty Trash",'C',4);

to.add("Feed dog",'A',2);

to.add("Feed bird",'B',7);

to.add("Mow lawn",'C',3);

to.add("Water lawn",'A',1);

to.add("Feed cat",'B',1);

while(!to.isEmpty())

{

System.out.println(to.remove());

}

}

}

/**output:

A1: Water lawn

A2: Feed dog

B1: Feed cat

B7: Feed bird

C3: Mow lawn

C4: Empty Trash

*/

package org.rui.collection2.queues;

import java.util.LinkedList;

/**

* 双向队列就是一个队列,但是你可以在任何一端添加或移除元素,

* LinkedList无法实现这样的接口,但可以使用组合来创建一个Deque类,

* @author lenovo

*

* @param

*/

public class Deque {

private LinkedList deque=new LinkedList();

public void addFirst(T e){deque.addFirst(e);}

public void addLast(T e){deque.addLast(e);}

public T getFirst(T e){return deque.getFirst();}

public T getLast(T e){return deque.getLast();}

public T removeFirst(){return deque.removeFirst();}

public T removeLast(){return deque.removeLast();}

public int size(){return deque.size();}

public String toString(){return deque.toString();}

//and other methods as necessary............

////////////////////////////////////////////////

public static void fillTest(Deque de)

{

for(int i=10;i<17;i++)

de.addFirst(i);

for(int i=50;i<55;i++)

de.addLast(i);

}

public static void main(String[] args) {

Deque deque=new Deque();

fillTest(deque);

System.out.println(deque);

while(deque.size()!=0)

System.out.print(deque.removeFirst()+" ");

System.out.println();

fillTest(deque);

while(deque.size()!=0)

System.out.print(deque.removeLast()+" ");

System.out.println();

}

}

/** output:

[16, 15, 14, 13, 12, 11, 10, 50, 51, 52, 53, 54]

16 15 14 13 12 11 10 50 51 52 53 54

54 53 52 51 50 10 11 12 13 14 15 16

*/

原文:http://blog.csdn.net/liangrui1988/article/details/30310125

/* * 基于双向链表实现双端队列结构 */ package dsa; public class Deque_DLNode implements Deque { protected DLNode header;//指向头节点(哨兵) protected DLNode trailer;//指向尾节点(哨兵) protected int size;//队列中元素的数目 //构造函数 public Deque_DLNode() { header = new DLNode(); trailer = new DLNode(); header.setNext(trailer); trailer.setPrev(header); size = 0; } //返回队列中元素数目 public int getSize() { return size; } //判断队列是否为空 public boolean isEmpty() { return (0 == size) ? true : false; } //取首元素(但不删除) public Object first() throws ExceptionQueueEmpty { if (isEmpty()) throw new ExceptionQueueEmpty("意外:双端队列为空"); return header.getNext().getElem(); } //取末元素(但不删除) public Object last() throws ExceptionQueueEmpty { if (isEmpty()) throw new ExceptionQueueEmpty("意外:双端队列为空"); return trailer.getPrev().getElem(); } //在队列前端插入新节点 public void insertFirst(Object obj) { DLNode second = header.getNext(); DLNode first = new DLNode(obj, header, second); second.setPrev(first); header.setNext(first); size++; } //在队列后端插入新节点 public void insertLast(Object obj) { DLNode second = trailer.getPrev(); DLNode first = new DLNode(obj, second, trailer); second.setNext(first); trailer.setPrev(first); size++; } //删除首节点 public Object removeFirst() throws ExceptionQueueEmpty { if (isEmpty()) throw new ExceptionQueueEmpty("意外:双端队列为空"); DLNode first = header.getNext(); DLNode second = first.getNext(); Object obj = first.getElem(); header.setNext(second); second.setPrev(header); size--; return(obj); } //删除末节点 public Object removeLast() throws ExceptionQueueEmpty { if (isEmpty()) throw new ExceptionQueueEmpty("意外:双端队列为空"); DLNode first = trailer.getPrev(); DLNode second = first.getPrev(); Object obj = first.getElem(); trailer.setPrev(second); second.setNext(trailer); size--; return(obj); } //遍历 public void Traversal() { DLNode p = header.getNext(); while (p != trailer) { System.out.print(p.getElem()+" "); p = p.getNex
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值