日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

java中用數組實現環形隊列的示例代碼

瀏覽:121日期:2022-08-14 11:28:16

本篇文章主要講述了使用數組實現環形隊列的思路以及具體代碼

一、隊列是什么

我們先來看下百科的解釋:隊列是一種特殊的線性表,特殊之處在于它只允許在表的前端(front)進行刪除操作,而在表的后端(rear)進行插入操作,隊列是一種操作受限制的線性表。進行插入操作的端稱為隊尾,進行刪除操作的端稱為隊頭。總結起來兩點:1.一種線性表2.添加操作只能在表尾,刪除操作在表頭(先進先出)

二、實現隊列的思路 1.初始化一個空隊列

初始化一個大小固定的數組,并將頭指針,尾指針都指向下表為0的位置,但其實這種初始化頭指針指向的是隊首,尾指針指向的是隊尾的后一個元素。

java中用數組實現環形隊列的示例代碼

2.往隊列里添加元素

往隊列里添加元素,尾指針后移一位。

java中用數組實現環形隊列的示例代碼

一直添加直到隊列滿

java中用數組實現環形隊列的示例代碼

這個時候尾指針已經出現在數組下標外了

3.消費隊列元素

每消費一個隊列元素,頭指針指向的元素出隊,并且后移一位

java中用數組實現環形隊列的示例代碼

再消費兩個

java中用數組實現環形隊列的示例代碼

這個時候我們想往隊列里繼續添加元素,尾指針后移,然后發現出現了假溢出的情況,因為尾指針無法再向后移動,而隊列實際上并沒有滿,我們又無法繼續往隊列里添加數據。這個時候其實有兩種解決方案。方案一:我們每消費一個元素,其后面的元素都整體往前移動一位,就像我們生活中排隊打飯一樣,后面的人都往前挪一挪。但這種方案帶來的后果是,帶來的時間開銷太大,因為基本上要操作所有的元素,所以這種方案不可行。方案二:尾指針在指向下表為最后一個元素時,再添加元素,如果還有空位,就將尾指針重新指向0,頭指針在取到下表數組末尾時,如果前面還有元素,頭指針也指向0,這就是我們說的環形隊列。

三、實現環形隊列1.環形隊列示例圖

尾指針重新指向零

java中用數組實現環形隊列的示例代碼

再添加一個元素

java中用數組實現環形隊列的示例代碼

連續消費三個元素,如果前面還有元素,頭指針也指向0

java中用數組實現環形隊列的示例代碼

這個時候我們發現那個原來熟悉的隊列又回來了。

2.代碼實現

/** * description:數組實現環形隊列 * author: xiaowang * */public class MyQueue<E> { // 隊列最大個數 private int size; // 元素真實個數 private int number; // 頭指針,指向隊列的第一個元素即隊頭 private int front; // 尾指針,指向隊尾的后一個元素(非隊尾) private int rear; // 隊列具體值 private Object[] values; // 隊列滿標記,當隊列是滿的時候為true private boolean isFullFlag; /**構造器*/ public MyQueue(int size){if (size<0){ throw new RuntimeException('初始化隊列時,隊列最大元素個數不能為負');}this.front = 0;this.rear = 0;this.number = 0;this.isFullFlag = false;this.size = size;this.values = new Object[size]; } /**往隊列里添加元素 添加成功返回true 失敗返回false*/ public boolean addToQueue(E e){// 判斷隊列是否已經滿了if (isFullFlag){ System.out.println('隊列已滿,無法繼續添加元素'); return false;}// 添加元素values[rear] = e;// 元素個數加一number++;// 尾指針后移一位,若已經指向數組最后的下表,則重新指向0if (rear == size-1){ rear = 0;}else{ rear++;}// 添加完這個元素,判斷隊列是否已經滿了,若滿則標記為trueif (rear==front){ isFullFlag = true;}return true; } /**從隊列里取出數據,隊頭數據*/ public E getFromQueue(){// 判斷隊列是否為空if (number==0||size==0){ System.out.println('隊列為空,無法從隊列中獲取數據'); return null;}// 臨時變量E e = (E) values[front];// 隊頭置空values[front] = null;// 個數減一number--;// 頭指針后移,若已經指向數組最后的下表,則重新指向0if (front==size-1){ front = 0;}else { front++;}// 取隊列之前若是滿的狀態,則更新狀態if (isFullFlag){ isFullFlag = false;}return e; } /**獲取目前有幾個元素正在進行排隊*/ public int getNumber(){return number; } /**獲取隊列的最大個數*/ public int getSize(){return size; } /**查看隊列在數組里保存的詳細情況*/ public String toString(){StringBuffer valueStr = new StringBuffer();valueStr.append('[');for (int i = 0; i < size; i++) { if (i!=size-1){valueStr.append(values[i]+','); }else{valueStr.append(values[i]+']'); }}return valueStr.toString(); }}

測試代碼

public class TestQueue { public static void main(String[] args) {MyQueue<String> queue = new MyQueue<String>(5);Scanner scanner = new Scanner(System.in);Scanner scanner2 = new Scanner(System.in);boolean isCan = true;while (isCan){ System.out.println('歡迎來到小王排隊系統,您可以使用以下功能。n添加:1;取出:2;展示:3;獲取排隊個數:4;退出:0。'); int flag = scanner.nextInt(); switch (flag){case 1 : System.out.println('請輸入一個數據:'); String data = scanner2.nextLine(); boolean isSuccess = queue.addToQueue(data); if (isSuccess){System.out.println('添加成功~~~'); } break;case 2 : String dataFromQueue = queue.getFromQueue(); if (dataFromQueue!=null){System.out.println('本次取出的數據為:'+dataFromQueue); } break;case 3 : System.out.println('隊列詳情為:n'+queue.toString()); break;case 4 : System.out.println('目前有'+queue.getNumber()+'個元素正在進行排隊'); break;default: isCan = false; System.out.println('已退出...'); break; }} }}總結

到此這篇關于java中用數組實現環形隊列的示例代碼的文章就介紹到這了,更多相關java 數組環形隊列內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
老司机精品视频在线播放| 久久人人88| 亚洲综合三区| 亚洲18在线| 日韩专区欧美专区| 免费视频亚洲| 98精品视频| 五月国产精品| 亚洲激情精品| 激情综合网址| 欧美日韩日本国产亚洲在线| 日韩欧美国产精品综合嫩v| 精品国产中文字幕第一页| 国产欧美激情| 精品精品99| 国产999精品在线观看 | 久久激情中文| 亚洲精品影视| 国产精品99精品一区二区三区∴| 日韩国产在线观看| 国产精品magnet| 丝袜a∨在线一区二区三区不卡| 福利在线免费视频| 7777精品| 人人爱人人干婷婷丁香亚洲| 999在线观看精品免费不卡网站| 国产精品第一| 国产欧美亚洲一区| 97精品一区| 91久久久精品国产| 亚洲精品激情| 国产精品网在线观看| 精品视频在线观看网站| 欧美日韩精品免费观看视完整 | 精品视频一区二区三区四区五区| 国产农村妇女精品一区二区| 精品国产美女a久久9999| 日韩av首页| 日韩高清欧美激情| 欧美jjzz| 麻豆久久久久久久| 日韩视频一区| 日本欧美国产| 亚洲免费毛片| 在线日韩欧美| 国产精品欧美日韩一区| 尹人成人综合网| 免费在线观看一区| 一本一道久久a久久精品蜜桃| 国产精品入口久久| 久久九九99| 日本在线一区二区三区| 久久精品欧洲| 国产农村妇女精品一二区| 亚洲午夜国产成人| 91欧美国产| 亚洲综合国产| 日本不卡在线视频| 国产中文一区| 日韩大片在线| av亚洲在线观看| 日韩精品亚洲专区| 国产精品毛片视频| 91一区二区三区四区| 99日韩精品| 国产精品普通话对白| 国内一区二区三区| 日本一不卡视频| 精品一区二区男人吃奶| 天堂а√在线最新版中文在线| 91精品国产经典在线观看| 成人精品亚洲| 久久精品国产亚洲一区二区三区| 国产精品99免费看| 国产精品免费看| 亚洲不卡系列| 美腿丝袜亚洲三区| 亚洲精品美女91| 伊人久久亚洲热| 蜜臀av在线播放一区二区三区| 国产欧美日韩影院| 久久婷婷亚洲| 欧美日韩一区二区三区四区在线观看| 99久久久久国产精品| 免费不卡在线视频| 99精品视频精品精品视频| 国产一区二区三区探花| 国产精品www.| 亚洲欧美网站在线观看| 丝袜美腿高跟呻吟高潮一区| 999国产精品999久久久久久| 成人在线视频免费| 亚洲午夜久久久久久尤物| 中文字幕成在线观看| 麻豆精品久久| 日韩精品国产欧美| 国产欧美日韩一级| 久久电影tv| 国产欧美一区二区三区米奇| 日韩激情中文字幕| 欧美日韩一区二区三区不卡视频 | 97国产精品| 亚洲18在线| 美女黄网久久| 美国三级日本三级久久99| 久久久影院免费| japanese国产精品| 一区二区自拍| 在线一区视频| 欧美日韩99| 麻豆成人av在线| 成年男女免费视频网站不卡| 成人台湾亚洲精品一区二区| 麻豆精品视频在线| 日韩在线短视频| 九一国产精品| 日本a级不卡| 91日韩欧美| 国产精成人品2018| 一区二区三区午夜视频| 久久狠狠久久| 麻豆视频在线看| 亚洲国产一区二区在线观看| 在线综合视频| 欧美日韩尤物久久| 亚洲精品少妇| 国产精品99一区二区三| 国产农村妇女精品一二区| 国产日本精品| 国产综合精品| 日本亚洲最大的色成网站www| 日韩88av| 日韩欧美一区二区三区在线观看 | 91亚洲成人| 神马日本精品| 国产亚洲精品v| 麻豆精品99| 国产午夜精品一区二区三区欧美| 久久精品 人人爱| 日韩不卡一区二区三区| 久久免费视频66| 亚洲精品在线国产| 久久精品导航| 免费在线日韩av| 男人操女人的视频在线观看欧美| 成人亚洲精品| 精品深夜福利视频| 国产一区二区三区四区五区传媒| 免费人成精品欧美精品| 日韩成人在线看| 日韩欧美一区二区三区在线观看 | 正在播放日韩精品| 国产模特精品视频久久久久| 久久亚洲精精品中文字幕| 怡红院精品视频在线观看极品| 日韩深夜视频| 日韩精品a在线观看91| 亚洲电影在线一区二区三区| 久久国产视频网| 视频一区二区三区中文字幕| 亚洲黄色免费看| 亚洲麻豆一区| 亚洲成人av观看| 久久av网址| 老牛影视一区二区三区| 国产精品高颜值在线观看| 国产精品综合色区在线观看| 综合国产精品| 亚洲久久视频| 亚洲丝袜美腿一区| 国模大尺度视频一区二区| 国内精品亚洲| 日韩av成人高清| 99国产精品99久久久久久粉嫩| 日韩精品欧美激情一区二区| 国产精品精品国产一区二区| 久久精品国产99国产精品| 国产另类在线| 国产视频一区二区在线播放| 91伊人久久| 国产精品欧美大片| 久久一区精品| 天堂av在线| 韩日一区二区三区| 野花国产精品入口| 三级亚洲高清视频| 亚洲人妖在线| 国产亚洲久久| 精品国产精品久久一区免费式 | 国产精品欧美在线观看| 国产一区二区三区不卡av| 亚洲精品极品| 在线看片一区| 免费日本视频一区| 亚洲在线观看| 精品国产一区二区三区av片| 黑丝一区二区| 日韩激情中文字幕| 久久不见久久见中文字幕免费| 国产精品专区免费|