队列的java实现
今天老师提出一个问题,就是如何用java实现队列呢?我在网上找了许多资料,发现java也是可以很轻松的实现队列。
如下代码:
package com; import java.util.Collection;
import java.util.Iterator;
import java.util.Queue; public class Aqueue implements Queue {
private Node first; private Node last; private int num; public Aqueue(){
this.first = null;
this.last = null;
this.num = 0;
}
@Override
public int size() {
return this.num;
} @Override
public boolean isEmpty() {
return false;
} @Override
public boolean contains(Object o) {
return false;
} @Override
public Iterator iterator() {
return null;
} @Override
public Object[] toArray() {
return new Object[0];
} @Override
public Object[] toArray(Object[] a) {
return new Object[0];
} @Override
public boolean add(Object o) {
Node node = new Node();
node.data = o;
if (this.first == null){
this.first = node;
this.last = node;
}else {
this.last.setNext(node);
this.last = node;
}
this.num++;
return true;
} @Override
public boolean remove(Object o) {
return false;
} @Override
public boolean addAll(Collection c) {
return false;
} @Override
public void clear() { } @Override
public boolean retainAll(Collection c) {
return false;
} @Override
public boolean removeAll(Collection c) {
return false;
} @Override
public boolean containsAll(Collection c) {
return false;
} @Override
public boolean offer(Object o) {
return false;
} @Override
public Object remove() {
return null;
} @Override
//返回到第一个元素出队列
public Object poll() { if (this.first == null){
return null;
}else {
Node n = this.first;
this.first = this.first.getNext();
n.setNext(null);
this.num--;
return n.getData();
}
} @Override
public Object element() {
return null;
} @Override
//返回到第一个元素,不出队列
public Object peek() {
return null;
}
private class Node{
//数据域
private Object data;
//引用域
private Node next; public Object getData() {
return data;
} public void setData(Object data) {
this.data = data;
} public Node getNext() {
return next;
} public void setNext(Node next) {
this.next = next;
}
}
}
用java自带的java.util.Queue就可以轻松实现,中间有好多方法没有实现,后期我再补上,接下来写测试类。
package test; import com.Aqueue; public class Test
{
public static void main(String[] args) {
Aqueue q = new Aqueue(); for (int i = 0; i < 100;i++){
q.add(i);
} int num = q.size();
for (int i = 0; i < num;i++){
System.out.println(q.poll());
}
}
}
ok,这样就可以实现了。
如果有啥不对的,请大哥们指明,小白涉世未深,急需指导。
队列的java实现的更多相关文章
- 算法_栈与队列的Java链表实现
		链表是一个递归的数据结构,它或者为null,或者是指向一个结点的引用,该结点含有一个泛型的元素和指向另一个链表的引用.可以用一个内部类来定义节点的抽象数据类型: private class Node ... 
- 数据结构之栈和队列及其Java实现
		栈和队列是数据结构中非常常见和基础的线性表,在某些场合栈和队列使用很多,因此本篇主要介绍栈和队列,并用Java实现基本的栈和队列,同时用栈和队列相互实现. 栈:栈是一种基于“后进先出”策略的线性表.在 ... 
- 数据结构--队列(Java实现)
		数据结构--队列(Java实现) 博客说明 文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢! 简介 队列是一种特殊的线性表,特殊之处在于它只 ... 
- 算法_队列的Java通用数组实现
		在实现Queue的API的时候,可以使用两个实例变量做索引,一个变量head指向队列的开头,另一个变量tail指向队列的结尾.在删除一个元素的时候,使用head访问,并将head+1,插入一个元素的时 ... 
- Java中的队列:java.util.Queue接口
		队列是一种特殊的线性表,它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作. Queue接口与List.Set同一级别,都是继承了Collection接口.Linked ... 
- 栈和队列的Java实现
		一. 栈 1.概念 栈是一种特殊的线性表,它只能在栈顶(top)进行插入(push)和删除(pop)操作. 栈的常用操作: 入栈(push):向栈顶插入元素 出栈(pop):从栈顶删除元素 访问栈顶 ... 
- Java Design Demo -简单的队列-异步多任务队列(java android)
		简单的单线程队列 -- 工作的时候遇到劣质打印机.给打印机发消息,打印机就会打印,如果在打印机还在打印的时候,就 再发消息打印,就会出现消息丢失.所以需要给上一个任务一些处理的间隔时间. 单线程的消息 ... 
- 数据结构队列的java实现,包括线性和链式两种方式
		实现的思路为: 采用泛型的方式,首先定义了一个Queue的接口,然后通过实现该接口实现了线性和链式的两种形式的队列: 接口代码如下: package com.peter.java.dsa.interf ... 
- 栈和队列的java简单实现
		今天看了一本书<啊哈 算法>,书的内容不多,一共两章,第一章是常见的排序算法包括桶排序.冒泡排序和快速排序,这些事基础的排序算法网上有很多资料说明,这里主要说第二章栈,对列,链表,书上使用 ... 
- 剑指offer-面试题7:俩个栈实现队列(java)
		详细分析请参照C语言版,这里仅仅给出实现代码,注释很详细,不得不说java各种api用起来真是爽飞了 1 package com.xsf.SordForOffer; 2 3 import java.u ... 
随机推荐
- 什么是实例内部类 Instance inner class有什么语法?
			1.Instance inner class定义,用途和用法 重要语法:马克-to-win:1)实例内部类一定得有个外层类的实例和它绑定在一起,所以可以用This指针.所以必须先实例化外层类之后才能再 ... 
- <wx-open-launch-weapp>详解
			demo图, h5跳转小程序 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ... 
- 面试官:说一说Zookeeper中Leader选举机制
			哈喽!大家好,我是小奇,一位不靠谱的程序员 小奇打算以轻松幽默的对话方式来分享一些技术,如果你觉得通过小奇的文章学到了东西,那就给小奇一个赞吧 文章持续更新 一.前言 今天又是一个阳光明媚的一天,我又 ... 
- Rb(redis blaster),一个为 redis 实现 non-replicated 分片的 python 库
			Rb,redis blaster,是一个为 redis 实现非复制分片(non-replicated sharding)的库.它在 python redis 之上实现了一个自定义路由系统,允许您自动定 ... 
- 启动jar包的shell脚本
			在jar包的同级目录新建文件例如:app_jar.sh 然后填写如下内容: #!/bin/bash #source /etc/profile # Auth:Liucx # Please change ... 
- [资源] 桃宝上十几块买的C#教程网盘
			我粗略的看了下觉得挺好的,分享给大家 链接:https://pan.baidu.com/s/1iHuLUXde4_L7NB-Zw9JWNg 提取码:1314 
- 实现深拷贝还在用JSON.parse(JSON.stringify(obj))?带你用JS实现一个完整版深拷贝函数
			使用JavaScript实现深拷贝 1.JSON序列化实现深拷贝 在JS中,想要对某一个对象(引用类型)进行一次简单的深拷贝,可以使用JSON提供给我们的两个方法. JSON.stringfy():可 ... 
- Nuxt 的介绍与安装
			Nuxt.js(一.介绍与安装) 1.为什么使用Nuxt 渐进式Vue.js框架给前后端分离带来无限的乐趣,越来越多的程序员选择Vue.在我们使用Vue框架的过程中不免会出现以下的一些问题: 如何更好 ... 
- Codeforces Round #762 (Div. 3), CDE
			(C) Wrong Addition Problem - C - Codeforces 题意 定义一种计算方式, 对于a+b=c, 给出a和c, 求b 题解 因为求法是从个位求得, 先求出来的最后输 ... 
- python相关知识理解
			Python3 基础了解 编码 Python 3 源码文件以 UTF-8 编码,所有字符串都是 unicode 字符串 # -*- coding: cp-1252 -*- 标识符 · 第一个字符 ... 
