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

[算法学习]基于数组实现的队列

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

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

    1. public interface Queue
    2.    
    3.       {  
    4.      /**
    5.       * 入队: 从队尾加入一元素
    6.       *  
    7.       * @param target
    8.       */  
    9.      public void add(E target);  
    10.    
    11.      /**
    12.       * 出队: 移走队头元素
    13.       *  
    14.       * @param target
    15.       * @return 当前队头元素
    16.       */  
    17.      public E remove();  
    18.    
    19.      /**
    20.       * 当前队列中的元素个数
    21.       */  
    22.      public int size();  
    23.    
    24.      /**
    25.       * 判断当前队列是否为空
    26.       *  
    27.       * @return
    28.       */  
    29.    
    30.      public boolean isEmpty();  
    31.      /**
    32.       * 只是返回队头元素
    33.       * @return
    34.       */  
    35.      public E front();  
    36. }  

    37.   /**
    38.   *基于数组的队列
    39.   * @param
    40.      
    41.       
    42.   */  
    43. public class ArrayQueue
    44.       
    45.         implements Queue
    46.       
    47.          {  
    48.      private E[] data;  
    49.       
    50.      private int size ;//队列中对象数量  
    51.       
    52.      private int front ;// 队列中第一个对象位置  
    53.       
    54.      private int rear ;//队列中当前对象位置  
    55.       
    56.      public ArrayQueue() {  
    57.          data = (E[]) new Object[10];  
    58.          size = 0;  
    59.          front = 0;  
    60.          rear = 0;  
    61.      }  
    62.    
    63.      public void add(E target) {  
    64.          if( isFull() ){  
    65.              enlarge();  
    66.              front = 0;  
    67.          }  
    68.          rear = (front + size) % data.length;  
    69.          data[rear] = target;  
    70.          size++;  
    71.      }  
    72.    
    73.      public E front() {  
    74.          if (isEmpty()) {  
    75.              throw new RuntimeException("队列为空!");  
    76.          }  
    77.          return data[front];  
    78.    
    79.      }  
    80.    
    81.      public boolean isEmpty() {  
    82.          return size == 0;  
    83.      }  
    84.    
    85.      public E remove() {  
    86.          if (isEmpty()) {  
    87.              throw new RuntimeException("队列为空!");  
    88.          }  
    89.          E tempData = data[front];  
    90.          data[front] = null;  
    91.          front = (front + 1) % (data.length);  
    92.          size--;  
    93.            
    94.          return tempData;  
    95.      }  
    96.       
    97.      public int size() {  
    98.          return size;  
    99.      }  
    100.      /**
    101.       * 判断当前队列是否已满
    102.       *  
    103.       * @return
    104.       */  
    105.      public boolean isFull() {  
    106.          return size == data.length;  
    107.      }  
    108.      /**
    109.       * 将数组容量扩大两倍
    110.       *  
    111.       */  
    112.      public void enlarge() {  
    113.          E[] newData = (E[]) new Object[data.length * 2];  
    114.          System.arraycopy(data, 0, newData, 0, data.length);  
    115.          data = newData;  
    116.          newData = null;  
    117.      }  
    118.    
    119. }  
    120. 测试代码:
    121.         

    122.     public void testArrayQueue(){  
    123.             ArrayQueue
    124.         
    125.           q = new ArrayQueue
    126.          
    127.           ();  
    128.             q.add("a");  
    129.             q.add("b");  
    130.             q.add("c");  
    131.             q.add("d");  
    132.             q.add("e");  
    133.             q.add("f");  
    134.             q.add("g");  
    135.            q.add("h");  
    136.            q.add("i");  
    137.            q.add("j");      
    138.            q.add("k");  
    139.            q.add("l");  
    140.            q.add("m");  
    141.            while( !q.isEmpty() ){  
    142.                String temp = q.remove();  
    143.                System.out.println(temp);  
    144.            }  
    145.        }  
    146.          
    147.         
    148.       
    149.       
    150.      
    151.    
    复制代码

       
         
         
          
          

            
          

            
          
         
       

      


    源码下载:http://file.javaxxz.com/2014/12/2/000631578.zip
    回复

    使用道具 举报

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

    本版积分规则

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

    GMT+8, 2025-2-25 04:09 , Processed in 0.355639 second(s), 34 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

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