国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 Java Java入門 java實(shí)作循環(huán)隊(duì)列

java實(shí)作循環(huán)隊(duì)列

Dec 31, 2019 pm 05:14 PM
java 循環(huán)隊(duì)列

java實(shí)作循環(huán)隊(duì)列

循環(huán)佇列的優(yōu)點(diǎn)

普通隊(duì)列出隊(duì)操作開銷大:在出隊(duì)操作時(shí),索引為0後面的所有元素,都需要往前移動(dòng)一位,元素越多,消耗的時(shí)間也越多,時(shí)間複雜度為O(N)。

循環(huán)隊(duì)列的邏輯:

1、當(dāng)元素較少時(shí)(tail位置在front後面),循環(huán)隊(duì)列與普通隊(duì)列出隊(duì)操作一樣,入隊(duì)的元素將會(huì)放在tail的位置上,隨後執(zhí)行tail 操作;出隊(duì)時(shí)front位置上的元素將會(huì)置null,隨後執(zhí)行front 操作;此時(shí)仍能保持著tail位置在front後面的狀態(tài),如下圖中所示:

java實(shí)作循環(huán)隊(duì)列

2、當(dāng)元素繼續(xù)添加,最後一個(gè)元素將放到索引為7的位置,此時(shí)tail位置將會(huì)移動(dòng)到隊(duì)首前面索引為0的位置上,此時(shí)tail在陣列的索引為變?yōu)椋?tail 1 )% capacity如下圖所示:

java實(shí)作循環(huán)隊(duì)列

##3、當(dāng)元素繼續(xù)加入時(shí),元素將會(huì)在tail位置上添加,tail繼續(xù)往後移動(dòng),如下圖所示:

java實(shí)作循環(huán)隊(duì)列

4、繼續(xù)添加元素,當(dāng)tail與front還相距一個(gè)單位時(shí),即此時(shí)數(shù)組還有一個(gè)空餘存儲(chǔ)空間,但當(dāng)前數(shù)組已經(jīng)不能繼續(xù)實(shí)現(xiàn)循環(huán)隊(duì)列的插入操作了,因?yàn)檠h(huán)隊(duì)列判斷隊(duì)列為空的條件就是front == tail,所以此時(shí)需要進(jìn)行擴(kuò)容操作;因此此處有意識(shí)的浪費(fèi)了一個(gè)空間。

此處可以推出,循環(huán)隊(duì)列元素滿的條件為:tail 1 == front(初步得出,後續(xù)會(huì)完善為(tail 1) % capacity == front )

5 、適當(dāng)情況下,此若時(shí)持續(xù)進(jìn)行出隊(duì)操作,front的位置也會(huì)從陣列最右端跳到陣列最左端開始。此時(shí)front在陣列的索引為變成:(front 1 )% capacity

程式碼實(shí)作:(相關(guān)影片教學(xué)分享:java影片教學(xué)

package dataStructure.chapter3;

/**
 * @Author: zjtMeng
 * @Date: 2019/12/28 20:13
 * @Version 1.0
 */
public class LoopQueue<E> implements Queue<E> {

    private E[] data;
    private int front,tail;
    private int size;

    public LoopQueue(int capacity){
        data = (E[]) new Object[capacity+1];
    }

    public LoopQueue(){
        this(10);
    }

    public int getCapacity(){
        return data.length-1;
    }

    /**
     * 循環(huán)隊(duì)列入隊(duì)操作
     * @param e
     */
    @Override
    public void enqueue(E e) {
        //循環(huán)隊(duì)列元素滿的判斷條件,如果滿了就進(jìn)行擴(kuò)容操作,擴(kuò)大兩倍
        if ((tail+1)%data.length == front)
            resize(2 * getCapacity());
        data[tail] = e;
        tail = (tail + 1) % data.length;
        size ++;

    }

    /**
     * 循環(huán)隊(duì)列擴(kuò)容
     * @param newCapacity
     */
    private void resize(int newCapacity){
        E[] newData = (E[]) new Object[newCapacity+1];
        //循環(huán)隊(duì)列第一種遍歷方式
        for (int i = 0 ; i < size ; i++ ){
//newData[]中的元素與data[]中的元素,一方面存在著front的偏移量,另一方面,data[]中的元素,
//可能在有部分處于front前面,因此此處采用對(duì)數(shù)組長(zhǎng)度取余,來判斷元素的位置
            newData[i] = data[(i+front)%data.length];
        }
        data = newData;
        front =0;
        tail = size;

    }

    @Override
    public E dequeue() {
        //首先判斷隊(duì)列是否為空,如果為空則拋出異常
        if (isEmpty())
            throw new IllegalArgumentException("Cannot dequeue from an empty queue.");
        E ret = data[front];
        //引用地址需要置空,否則JVM不能及時(shí)回收空間,從而可能會(huì)出現(xiàn)OOM異常
        data[front] = null;
        front = (front + 1 )% data.length;
        size--;
        //如果元素?cái)?shù)量達(dá)到隊(duì)列容積的1/4,且隊(duì)列容積/2 不等于0時(shí),進(jìn)行縮容操作
        if (size == getCapacity() / 4 && getCapacity() / 2 != 0 )
            resize(getCapacity() / 2);
        return ret;
    }

    /**
     * 查看隊(duì)首元素
     * @return
     */
    @Override
    public E getFront() {
        if (isEmpty())
            throw new IllegalArgumentException("Queue is empty.");
        return data[front];
    }

    @Override
    public int getSize() {
        return size;
    }

    /**
     * 判斷循隊(duì)列是否為空
     * @return
     */
    @Override
    public boolean isEmpty() {
        return front == tail;
    }

    @Override
    public String toString(){
        StringBuilder res = new StringBuilder();
        res.append(String.format("Queue: size = %d, capacity = %d\n",size, getCapacity()));
        res.append("front[");
        //循環(huán)隊(duì)列遍歷的第二種方法
        for (int i = front; i != tail; i = (i + 1) % data.length){
            res.append(data[i]);
            //循環(huán)隊(duì)列未遍歷到隊(duì)尾的標(biāo)志
            if ((i + 1) % data.length != tail)
                res.append(", ");
        }
        res.append("] tail");
        return res.toString();
    }
}

相關(guān)文章教學(xué)推薦:

java入門教學(xué)#

以上是java實(shí)作循環(huán)隊(duì)列的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1601
29
PHP教程
1502
276
如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動(dòng)提交模式,再執(zhí)行多個(gè)操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務(wù);2.執(zhí)行多個(gè)SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時(shí)應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點(diǎn)實(shí)現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當(dāng)前日期時(shí)間;3.使用of()方法創(chuàng)建特定日期時(shí)間;4.利用plus/minus方法不可變地增減時(shí)間;5.使用ZonedDateTime和ZoneId處理時(shí)區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時(shí)通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

比較Java框架:Spring Boot vs Quarkus vs Micronaut 比較Java框架:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

前形式攝取,quarkusandmicronautleaddueTocile timeProcessingandGraalvSupport,withquarkusoftenpernperforminglightbetterine nosserless notelless centarios.2。

了解網(wǎng)絡(luò)端口和防火牆 了解網(wǎng)絡(luò)端口和防火牆 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

垃圾收集如何在Java工作? 垃圾收集如何在Java工作? Aug 02, 2025 pm 01:55 PM

Java的垃圾回收(GC)是自動(dòng)管理內(nèi)存的機(jī)制,通過回收不可達(dá)對(duì)象釋放堆內(nèi)存,減少內(nèi)存洩漏風(fēng)險(xiǎn)。 1.GC從根對(duì)象(如棧變量、活動(dòng)線程、靜態(tài)字段等)出發(fā)判斷對(duì)象可達(dá)性,無法到達(dá)的對(duì)像被標(biāo)記為垃圾。 2.基於標(biāo)記-清除算法,標(biāo)記所有可達(dá)對(duì)象,清除未標(biāo)記對(duì)象。 3.採用分代收集策略:新生代(Eden、S0、S1)頻繁執(zhí)行MinorGC;老年代執(zhí)行較少但耗時(shí)較長(zhǎng)的MajorGC;Metaspace存儲(chǔ)類元數(shù)據(jù)。 4.JVM提供多種GC器:SerialGC適用於小型應(yīng)用;ParallelGC提升吞吐量;CMS降

使用HTML'輸入類型”作為用戶數(shù)據(jù) 使用HTML'輸入類型”作為用戶數(shù)據(jù) Aug 03, 2025 am 11:07 AM

選擇合適的HTMLinput類型能提升數(shù)據(jù)準(zhǔn)確性、增強(qiáng)用戶體驗(yàn)並提高可用性。 1.根據(jù)數(shù)據(jù)類型選用對(duì)應(yīng)input類型,如text、email、tel、number和date,可實(shí)現(xiàn)自動(dòng)校驗(yàn)和適配鍵盤;2.利用HTML5新增類型如url、color、range和search,可提供更直觀的交互方式;3.配合使用placeholder和required屬性,可提升表單填寫效率和正確率,但需注意placeholder不能替代label。

以身作則http中間件記錄示例 以身作則http中間件記錄示例 Aug 03, 2025 am 11:35 AM

Go中的HTTP日誌中間件可記錄請(qǐng)求方法、路徑、客戶端IP和耗時(shí),1.使用http.HandlerFunc包裝處理器,2.在調(diào)用next.ServeHTTP前後記錄開始時(shí)間和結(jié)束時(shí)間,3.通過r.RemoteAddr和X-Forwarded-For頭獲取真實(shí)客戶端IP,4.利用log.Printf輸出請(qǐng)求日誌,5.將中間件應(yīng)用於ServeMux實(shí)現(xiàn)全局日誌記錄,完整示例代碼已驗(yàn)證可運(yùn)行,適用於中小型項(xiàng)目起步,擴(kuò)展建議包括捕獲狀態(tài)碼、支持JSON日誌和請(qǐng)求ID追蹤。

比較Java構(gòu)建工具:Maven vs. Gradle 比較Java構(gòu)建工具:Maven vs. Gradle Aug 03, 2025 pm 01:36 PM

Gradleisthebetterchoiceformostnewprojectsduetoitssuperiorflexibility,performance,andmoderntoolingsupport.1.Gradle’sGroovy/KotlinDSLismoreconciseandexpressivethanMaven’sverboseXML.2.GradleoutperformsMaveninbuildspeedwithincrementalcompilation,buildcac

See all articles