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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
/* * 基于双向链表实现双端队列结构 */ 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
程序 = 数据结构 + 算法  程序是为了解决实际问题而存在的。然而为了解决问题,必定会使用到某些数据结构以及设计一个解决这种数据结构的算法。如果说各种编程语言是程序员的招式,那么数据结构和算法就相当于程序员的内功。编程实战算法,不是念PPT,我们讲的就是实战与代码实现与企业应用。程序 = 数据结构 + 算法                ——图灵奖得主,计算机科学家N.Wirth(沃斯)作为程序员,我们做机器学习也好,做python开发也好,java开发也好。有一种对所有程序员无一例外的刚需 —— 算法与数据结构日常增删改查 + 粘贴复制 + 搜索引擎可以实现很多东西。同样,这样也是没有任何竞争力的。我们只可以粘贴复制相似度极高的功能,稍复杂的逻辑没有任何办法。语言有很多,开发框架更是日新月异3个月不学就落后我们可以学习很多语言,很多框架,但招聘不会考你用5种语言10种框架实现同一个功能。真正让程序员有区分度,企业招聘万年不变的重点 —— 算法与数据结构。算法代表程序员水平的珠穆朗玛。 本视频由微软全球最有价值专家尹成录制,拒绝念PPT,代码实战数据结构与算法导论。除了传统数据结构算法,加入高并发线程安全数据结构,分布式负载均衡算法,分布式哈希表,分布式排序等等现代算法。  算法,晦涩难懂,却又是IT领域受重视的素养之一。可以说,算法能力往往决定了一个程序员能够走多远。因此,BAT/FLAG等国内外各大名企非常喜欢在面试环节考核求职者的算法编程,这也成为了无数准程序员们过不去的一道“坎”。如何入门并成为一名出色的算法工程师?但无论半路出家还是科班出身,除学生时代搞算法竞赛的同学外真正用心学习过算法与数据结构太少太少。对于后期想要学习算法与数据结构却不得不面对以下问题:没有自己的知识框架,无法关联知识点,学习效率低有疑问而无人解答,有问题无法理解全靠猜测,一个问题卡好几天市面上资料题解质量参差不齐,正确性未可知Google算法-工程师尹成大哥学习算法。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值