Java棧學習筆記

一、棧數據結構

Java中棧是一種基本數據結構,它具有“後進先出”的特點:最後進入棧中的元素最先被取出。

Java中棧的實現方式有兩種:數組實現和鏈表實現。


//數組實現
public class ArrayStack {
    private int[] arr;
    private int top;//棧頂指針
    public ArrayStack(int capacity) {
        this.arr = new int[capacity];
        this.top = -1;
    }
    public boolean isEmpty() {
        return top == -1;
    }
    public boolean isFull() {
        return top == arr.length - 1;
    }
    public void push(int data) {
        if (isFull()) {
            throw new RuntimeException("棧已滿");
        }
        arr[++top] = data;
    }
    public int pop() {
        if (isEmpty()) {
            throw new RuntimeException("棧為空");
        }
        return arr[top--];
    }
}

鏈表實現的棧相對於數組實現的棧,在動態擴容方面更為便捷,在鏈表頭部進行插入和刪除操作更為高效。

二、基本應用

棧在Java中有很多基本應用,如函數調用棧、表達式求值、括號匹配檢查、漢諾塔等。

三、應用擴展

1. 單調棧

單調棧是基於棧數據結構實現的特化版本,其具有以下特點:

1) 只存儲特定方向的數據,在單調遞增棧中,棧從棧底到棧頂的元素是遞增的;在單調遞減棧中,棧從棧底到棧頂的元素是遞減的。

2) 當新元素入棧時,棧內原有比其小(大)的元素都會被彈出。從而能夠在O(n)的時間複雜度內解決一些很難用暴力算法解決的問題。

單調棧可以用於解決一些最值問題,如找出一個數組中元素右邊第一個比他大的數、找出一個數組中元素左右兩邊最近的比他大的數等。


public int[] findRightMax(int[] arr) {
    int len = arr.length;
    int[] res = new int[len];
    Stack<Integer> stack = new Stack();
    for(int i = 0; i < len; i++) {
        while(!stack.isEmpty() && arr[i] > arr[stack.peek()]) {
            int top = stack.pop();
            res[top] = i;
        }
        stack.push(i);
    }
    while(!stack.isEmpty()) {
        res[stack.pop()] = -1;
    }
    return res;
}

2. 模擬遞歸

在遞歸中,函數調用棧起着關鍵作用。但是在某些情況下,遞歸調用棧可能會耗盡堆棧空間,尤其在計算深度大的遞歸時。

為了克服這個問題,我們可以使用Java中的棧數據結構自己實現遞歸調用。


public static int recursion(int n) {
    Stack<Integer> stack = new Stack();
    int res = 0;
    stack.push(n);
    while(!stack.isEmpty()) {
        int tmp = stack.pop();
        if(tmp == 1) {
            res += 1;
        } else {
            stack.push(tmp - 1);
            stack.push(tmp - 2);
        }
    }
    return res;
}

3. 開發工具

在Java開發中,棧也被廣泛應用於開發工具的實現。如命令行模式下的命令歷史棧,文本編輯器中的撤銷操作棧等。

四、總結

本文通過對Java中棧數據結構的分析,詳細介紹了棧的基本應用,及擴展的應用在Java中的實際應用。了解和熟練運用Java中的棧數據結構可以幫助我們更好地解決實際問題。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/190255.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-29 22:32
下一篇 2024-11-29 22:32

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Python學習筆記:去除字符串最後一個字符的方法

    本文將從多個方面詳細闡述如何通過Python去除字符串最後一個字符,包括使用切片、pop()、刪除、替換等方法來實現。 一、字符串切片 在Python中,可以通過字符串切片的方式來…

    編程 2025-04-29

發表回復

登錄後才能評論