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入门到精通教程
查看: 651|回复: 0

java基于数组实现的队列 实例

[复制链接]

该用户从未签到

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


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);  
           }  
       }  
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-10 23:47 , Processed in 0.332651 second(s), 35 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

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