Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 768|回复: 0

基于数组实现的队列

[复制链接]

该用户从未签到

发表于 2011-9-12 22:41:42 | 显示全部楼层 |阅读模式
      队列是一种特殊的线性表,它只允许在表的前端进行删除操作,而在表的后端进行插入操作。进行插入操作的端称为队尾,进行删除操作的端称为队头。这也就是我 们平常经常用说到的先进先出原则(FIFO)。java 中的 List 就可以作为队列来使用,在队列尾部添加元素则使用 list.add 方法,从队列头部删除元素则使用 list.remove 方法。


[pre] public interface Queue {       /**       * 入队: 从队尾加入一元素       *        * @param target       */       public void add(E target);          /**       * 出队: 移走队头元素       *        * @param target       * @return 当前队头元素       */       public E remove();          /**       * 当前队列中的元素个数       */       public int size();          /**       * 判断当前队列是否为空       *        * @return       */          public boolean isEmpty();       /**       * 只是返回队头元素       * @return       */       public E front();   }     /**   *基于数组的队列   * @param    */   public class ArrayQueue implements Queue {       private E[] data;              private int size ;//队列中对象数量              private int front ;// 队列中第一个对象位置              private int rear ;//队列中当前对象位置              public ArrayQueue() {           data = (E[]) new Object[10];           size = 0;           front = 0;           rear = 0;       }          public void add(E target) {           if( isFull() ){               enlarge();               front = 0;           }           rear = (front + size) % data.length;           data[rear] = target;           size++;       }          public E front() {           if (isEmpty()) {               throw new RuntimeException("队列为空!");           }           return data[front];          }          public boolean isEmpty() {           return size == 0;       }          public E remove() {           if (isEmpty()) {               throw new RuntimeException("队列为空!");           }           E tempData = data[front];           data[front] = null;           front = (front + 1) % (data.length);           size--;                      return tempData;       }              public int size() {           return size;       }       /**       * 判断当前队列是否已满       *        * @return       */       public boolean isFull() {           return size == data.length;       }       /**       * 将数组容量扩大两倍       *        */       public void enlarge() {           E[] newData = (E[]) new Object[data.length * 2];           System.arraycopy(data, 0, newData, 0, data.length);           data = newData;           newData = null;       }      }  测试代码:
    public void testArrayQueue(){              ArrayQueue q = new ArrayQueue();              q.add("a");              q.add("b");              q.add("c");              q.add("d");              q.add("e");              q.add("f");              q.add("g");             q.add("h");             q.add("i");             q.add("j");                  q.add("k");             q.add("l");             q.add("m");             while( !q.isEmpty() ){                 String temp = q.remove();                 System.out.println(temp);             }         }  [/pre]
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2024-4-28 00:47 , Processed in 0.362446 second(s), 34 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表