欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

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

一、概述:

1、原理:

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

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

2、示例圖:

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

package com.java.queue;
/**
 * @描述 對(duì)列
 * @項(xiàng)目名稱 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;// 有效長(zhǎng)度
 private int head;// 隊(duì)頭
 private int end;// 隊(duì)尾
 public CycleQueue(int size) {
 this.maxSize = size;
 this.arr = new long[maxSize];
 this.len = 0;
 this.head = 0;
 this.end = -1;
 }
 /**
 * 從隊(duì)尾插入數(shù)據(jù)
 *
 * @param value
 */
 public void insert(long value) {
 //如果滿了,為什么是maxSize - 1 ,因?yàn)閺?1開(kāi)始
 if (end == maxSize - 1) {
  end = -1;
 }
 arr[++end] = value;
 len++;
 }
 /**
 * 從隊(duì)頭移除數(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);
 }
 /**
 * 獲得隊(duì)列的有效長(zhǎng)度
 *
 * @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("腳本之家測(cè)試結(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() + " ");
 }
 }
}

運(yùn)行結(jié)果:

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

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    Java異常處理深入理解

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

最新評(píng)論