电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:62日期: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
相關文章:
主站蜘蛛池模板: 高温高压釜(氢化反应釜)百科 | 在线浊度仪_悬浮物污泥浓度计_超声波泥位计_污泥界面仪_泥水界面仪-无锡蓝拓仪表科技有限公司 | 杭州实验室尾气处理_实验台_实验室家具_杭州秋叶实验设备有限公司 | 防火门|抗爆门|超大门|医疗门|隔声门-上海加汇门业生产厂家 | 南京种植牙医院【官方挂号】_南京治疗种植牙医院那个好_南京看种植牙哪里好_南京茀莱堡口腔医院 尼龙PA610树脂,尼龙PA612树脂,尼龙PA1010树脂,透明尼龙-谷骐科技【官网】 | 低噪声电流前置放大器-SR570电流前置放大器-深圳市嘉士达精密仪器有限公司 | 瓶盖扭矩测试仪-瓶盖扭力仪-全自动扭矩仪-济南三泉中石单品站 | 高压分散机(高压细胞破碎仪)百科-北京天恩瀚拓 | 防水套管_柔性防水套管_刚性防水套管-巩义市润达管道设备制造有限公司 | 污泥烘干机-低温干化机-工业污泥烘干设备厂家-焦作市真节能环保设备科技有限公司 | 智慧农业|农业物联网|现代农业物联网-托普云农物联网官方网站 | 联系我们-腾龙公司上分客服微信19116098882 | 集装袋吨袋生产厂家-噸袋廠傢-塑料编织袋-纸塑复合袋-二手吨袋-太空袋-曹县建烨包装 | 喷漆房_废气处理设备-湖北天地鑫环保设备有限公司| 旋振筛|圆形摇摆筛|直线振动筛|滚筒筛|压榨机|河南天众机械设备有限公司 | 掺铥光纤放大器-C/L波段光纤放大器-小信号光纤放大器-合肥脉锐光电技术有限公司 | 网站建设-临朐爱采购-抖音运营-山东兆通网络科技 | 防火卷帘门价格-聊城一维工贸特级防火卷帘门厂家▲ | 儿童乐园|游乐场|淘气堡招商加盟|室内儿童游乐园配套设备|生产厂家|开心哈乐儿童乐园 | 【法利莱住人集装箱厂家】—活动集装箱房,集装箱租赁_大品牌,更放心 | 耐火浇注料价格-高强高铝-刚玉碳化硅耐磨浇注料厂家【直销】 | 全自动贴标机-套标机-工业热风机-不干胶贴标机-上海厚冉机械 | PAS糖原染色-CBA流式多因子-明胶酶谱MMP-上海研谨生物科技有限公司 | 胶原检测试剂盒,弹性蛋白检测试剂盒,类克ELISA试剂盒,阿达木单抗ELISA试剂盒-北京群晓科苑生物技术有限公司 | 外贮压-柜式-悬挂式-七氟丙烷-灭火器-灭火系统-药剂-价格-厂家-IG541-混合气体-贮压-非贮压-超细干粉-自动-灭火装置-气体灭火设备-探火管灭火厂家-东莞汇建消防科技有限公司 | 耳模扫描仪-定制耳机设计软件-DLP打印机-asiga打印机-fitshape「飞特西普」 | 超高频感应加热设备_高频感应电源厂家_CCD视觉检测设备_振动盘视觉检测设备_深圳雨滴科技-深圳市雨滴科技有限公司 | 代写标书-专业代做标书-商业计划书代写「深圳卓越创兴公司」 | PCB设计,PCB抄板,电路板打样,PCBA加工-深圳市宏力捷电子有限公司 | 超声波成孔成槽质量检测仪-压浆机-桥梁预应力智能张拉设备-上海硕冠检测设备有限公司 | 运动木地板厂家,篮球场木地板品牌,体育场馆木地板安装 - 欧氏运动地板 | 冷水机-工业冷水机-冷水机组-欧科隆品牌保障 | 激光内雕_led玻璃_发光玻璃_内雕玻璃_导光玻璃-石家庄明晨三维科技有限公司 激光内雕-内雕玻璃-发光玻璃 | 济南网站策划设计_自适应网站制作_H5企业网站搭建_济南外贸网站制作公司_锐尚 | 鲁尔圆锥接头多功能测试仪-留置针测试仪-上海威夏环保科技有限公司 | 铁盒_铁罐_马口铁盒_马口铁罐_铁盒生产厂家-广州博新制罐 | 天然鹅卵石滤料厂家-锰砂滤料-石英砂滤料-巩义东枫净水 | 定量包装机,颗粒定量包装机,粉剂定量包装机,背封颗粒包装机,定量灌装机-上海铸衡电子科技有限公司 | 沈飞防静电地板__机房地板-深圳市沈飞防静电设备有限公司 | 工控机-图像采集卡-PoE网卡-人工智能-工业主板-深圳朗锐智科 | 自动配料系统_称重配料控制系统厂家 |