亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java數(shù)據(jù)結(jié)構(gòu)之循環(huán)隊列簡單定義與用法示例

 更新時間:2017年10月24日 10:09:36   作者:CharlinGod  
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之循環(huán)隊列簡單定義與用法,簡要描述了循環(huán)隊列的概念、原理,并結(jié)合實例形式分析了java循環(huán)隊列的定義與使用方法,需要的朋友可以參考下

本文實例講述了Java數(shù)據(jù)結(jié)構(gòu)之循環(huán)隊列簡單定義與用法。分享給大家供大家參考,具體如下:

一、概述:

1、原理:

與普通隊列的區(qū)別在于循環(huán)隊列添加數(shù)據(jù)時,如果其有效數(shù)據(jù)end == maxSize - 1(最大空間)的話,end指針又移動到-1的位置

刪除數(shù)據(jù)時,如果head== maxSize時 head指針移動到0的位置

2、示例圖:

二、實現(xiàn)代碼:

package com.java.queue;
/**
 * @描述 對列
 * @項目名稱 Java_DataStruct
 * @包名 com.java.stack
 * @類名 Queue
 * @author chenlin
 * @version 1.0
 * @SVN $Rev$
 */
public class CycleQueue {
 private long[] arr;
 private int maxSize;// 最大空間
 private int len;// 有效長度
 private int head;// 隊頭
 private int end;// 隊尾
 public CycleQueue(int size) {
 this.maxSize = size;
 this.arr = new long[maxSize];
 this.len = 0;
 this.head = 0;
 this.end = -1;
 }
 /**
 * 從隊尾插入數(shù)據(jù)
 *
 * @param value
 */
 public void insert(long value) {
 //如果滿了,為什么是maxSize - 1 ,因為從-1開始
 if (end == maxSize - 1) {
  end = -1;
 }
 arr[++end] = value;
 len++;
 }
 /**
 * 從隊頭移除數(shù)據(jù)
 */
 public long remove() {
 long result = arr[head++];
 if (head == maxSize) {
  head = 0;
 }
 len--;
 return result;
 }
 /**
 * 判斷是否為空
 *
 * @return
 */
 public boolean isEmpty() {
 return (len == 0);
 }
 /**
 * 判斷是否滿了
 *
 * @return
 */
 public boolean isFull() {
 return (len == maxSize);
 }
 /**
 * 獲得隊列的有效長度
 *
 * @return
 */
 public int size() {
 return len;
 }
 public static void main(String[] args) {
 CycleQueue queue = new CycleQueue(50);
 queue.insert(22);
 queue.insert(33);
 queue.insert(44);
 queue.insert(534);
 queue.insert(21);
 queue.insert(55);
 System.out.println("腳本之家測試結(jié)果:");
 while (!queue.isEmpty()) {
  System.out.print(queue.remove() + " ");
 }
 System.out.println();
 queue.insert(33);
 queue.insert(13);
 queue.insert(23);
 while (!queue.isEmpty()) {
  System.out.print(queue.remove() + " ");
 }
 }
}

運行結(jié)果:

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總

希望本文所述對大家java程序設(shè)計有所幫助。

相關(guān)文章

  • 基于mybatis-plus-generator實現(xiàn)代碼自動生成器

    基于mybatis-plus-generator實現(xiàn)代碼自動生成器

    這篇文章專門為小白準(zhǔn)備了入門級mybatis-plus-generator代碼自動生成器,可以提高開發(fā)效率。文中的示例代碼講解詳細(xì),感興趣的可以了解一下
    2022-05-05
  • java內(nèi)存分布實現(xiàn)代碼

    java內(nèi)存分布實現(xiàn)代碼

    這篇文章主要介紹了淺談Java內(nèi)存區(qū)域劃分和內(nèi)存分配策略,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07
  • Spring security密碼加密實現(xiàn)代碼實例

    Spring security密碼加密實現(xiàn)代碼實例

    這篇文章主要介紹了Spring security密碼加密實現(xiàn)代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04
  • springboot項目引入外部jar包的詳細(xì)圖文教程

    springboot項目引入外部jar包的詳細(xì)圖文教程

    在項目中有時候需要引入外部jar包,啟動運行,下面這篇文章主要給大家介紹了關(guān)于springboot項目引入外部jar包的詳細(xì)圖文教程,需要的朋友可以參考下
    2023-09-09
  • web.xml?SpringBoot打包可執(zhí)行Jar運行SpringMVC加載流程

    web.xml?SpringBoot打包可執(zhí)行Jar運行SpringMVC加載流程

    這篇文章主要為大家介紹了web.xml?SpringBoot打包可執(zhí)行Jar運行SpringMVC加載流程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Gson之toJson和fromJson方法的具體使用

    Gson之toJson和fromJson方法的具體使用

    Gson是Google的一個開源項目,可以將Java對象轉(zhuǎn)換成JSON,也可能將JSON轉(zhuǎn)換成Java對象。本文就詳細(xì)的介紹了toJson和fromJson方法的具體使用,感興趣的可以了解一下
    2021-11-11
  • Java實現(xiàn)求子數(shù)組和的最大值算法示例

    Java實現(xiàn)求子數(shù)組和的最大值算法示例

    這篇文章主要介紹了Java實現(xiàn)求子數(shù)組和的最大值算法,涉及Java數(shù)組遍歷、判斷、運算等相關(guān)操作技巧,需要的朋友可以參考下
    2018-02-02
  • springboot如何實現(xiàn)前后端分離跨域訪問

    springboot如何實現(xiàn)前后端分離跨域訪問

    這篇文章主要介紹了springboot如何實現(xiàn)前后端分離跨域訪問問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • java中的數(shù)組初始化賦初值方式

    java中的數(shù)組初始化賦初值方式

    這篇文章主要介紹了java中的數(shù)組初始化賦初值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Java異常處理深入理解

    Java異常處理深入理解

    這篇文章主要介紹了java項目常用異常處理匯總,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2021-07-07

最新評論