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

Java實現(xiàn)滑動窗口算法的示例代碼

 更新時間:2025年03月19日 08:45:21   作者:拾荒的小海螺  
滑動窗口算法是一種高效解決子數(shù)組、子字符串問題的算法,廣泛應(yīng)用于數(shù)據(jù)流處理、網(wǎng)絡(luò)限流和字符串操作等場景,本文將詳細(xì)解析滑動窗口算法的核心思想、常見問題及其實現(xiàn)方式,需要的朋友可以參考下

1、簡述

滑動窗口算法是一種高效解決子數(shù)組、子字符串問題的算法,廣泛應(yīng)用于數(shù)據(jù)流處理、網(wǎng)絡(luò)限流和字符串操作等場景。本文將詳細(xì)解析滑動窗口算法的核心思想、常見問題及其實現(xiàn)方式,并結(jié)合具體示例和實際應(yīng)用場景進(jìn)行說明。

2、核心思想

滑動窗口是一種雙指針技術(shù),維護(hù)一個能夠在數(shù)據(jù)結(jié)構(gòu)上"滑動"的窗口(通常由兩個指針表示)。通過動態(tài)調(diào)整窗口的范圍,優(yōu)化計算的時間復(fù)雜度。

基本步驟:

  • 初始化兩個指針 left 和 right,分別表示窗口的左邊界和右邊界。
  • 移動 right 指針擴(kuò)大窗口,直到窗口滿足問題的條件。
  • 在滿足條件時,移動 left 指針縮小窗口,尋找更優(yōu)解或移除不必要的元素。
  • 重復(fù)上述過程,直到 right 遍歷完整個數(shù)據(jù)結(jié)構(gòu)。

3、實踐樣例

以下是幾個經(jīng)典問題的滑動窗口解法:

3.1 找到字符串中所有不重復(fù)字符的最長子串

給定一個字符串,找出其中不含重復(fù)字符的最長子串。

import java.util.HashSet;

public class LongestSubstringWithoutRepeatingChars {
    public int lengthOfLongestSubstring(String s) {
        int left = 0, right = 0, maxLength = 0;
        HashSet<Character> window = new HashSet<>();

        while (right < s.length()) {
            char c = s.charAt(right);
            if (!window.contains(c)) {
                window.add(c);
                maxLength = Math.max(maxLength, right - left + 1);
                right++;
            } else {
                window.remove(s.charAt(left));
                left++;
            }
        }

        return maxLength;
    }

    public static void main(String[] args) {
        LongestSubstringWithoutRepeatingChars solution = new LongestSubstringWithoutRepeatingChars();
        System.out.println(solution.lengthOfLongestSubstring("abcabcbb")); // Output: 3
    }
}

3.2 滑動窗口最大值

給定一個數(shù)組 nums 和一個大小為 k 的窗口,找到每個滑動窗口中的最大值。

import java.util.ArrayDeque;
import java.util.Deque;

public class SlidingWindowMaximum {
    public int[] maxSlidingWindow(int[] nums, int k) {
        if (nums == null || nums.length == 0) return new int[0];
        int n = nums.length;
        int[] result = new int[n - k + 1];
        Deque<Integer> deque = new ArrayDeque<>();

        for (int i = 0; i < nums.length; i++) {
            // 移除窗口左側(cè)已過期的元素
            if (!deque.isEmpty() && deque.peekFirst() < i - k + 1) {
                deque.pollFirst();
            }

            // 移除所有比當(dāng)前元素小的元素,因為它們不會成為最大值
            while (!deque.isEmpty() && nums[deque.peekLast()] < nums[i]) {
                deque.pollLast();
            }

            deque.offerLast(i);

            // 當(dāng)窗口達(dá)到大小 k 時,記錄最大值
            if (i >= k - 1) {
                result[i - k + 1] = nums[deque.peekFirst()];
            }
        }

        return result;
    }

    public static void main(String[] args) {
        SlidingWindowMaximum solution = new SlidingWindowMaximum();
        int[] result = solution.maxSlidingWindow(new int[]{1,3,-1,-3,5,3,6,7}, 3);
        for (int r : result) {
            System.out.print(r + " ");
        }
        // Output: 3 3 5 5 6 7
    }
}

4、應(yīng)用場景

滑動窗口算法因其高效性,在以下場景中應(yīng)用廣泛:

  • 字符串處理:
    查找字符串中的子串問題,例如最長無重復(fù)子串、包含所有指定字符的最短子串。

  • 數(shù)據(jù)流處理:
    在處理實時數(shù)據(jù)流時,通過滑動窗口維護(hù)最近的狀態(tài),例如計算實時統(tǒng)計信息(平均值、最大值等)。

  • 網(wǎng)絡(luò)限流:
    滑動窗口用于實現(xiàn)動態(tài)限流算法,限制一段時間內(nèi)的請求數(shù)量。

  • 數(shù)組處理:
    處理固定窗口大小的問題,例如滑動窗口最大值、最小值等。

5、總結(jié)

滑動窗口算法通過動態(tài)調(diào)整窗口范圍,極大地提高了求解某些問題的效率。在實際開發(fā)中,可以結(jié)合問題的特點(diǎn)靈活使用滑動窗口 技術(shù)解決各種復(fù)雜問題。如果你還沒有在項目中嘗試滑動窗口算法,那么不妨以本文提供的代碼示例為起點(diǎn),嘗試將其應(yīng)用到實際場景中。

以上就是Java實現(xiàn)滑動窗口算法的示例代碼的詳細(xì)內(nèi)容,更多關(guān)于Java滑動窗口算法的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • java泛型常用通配符實例解析

    java泛型常用通配符實例解析

    這篇文章主要介紹了java泛型常用通配符實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • CommandLineRunner最佳實踐小結(jié)

    CommandLineRunner最佳實踐小結(jié)

    CommandLineRunner是Spring Boot框架提供的一個功能接口,用于Spring Boot應(yīng)用啟動完成后立即執(zhí)行特定的代碼邏輯,允許開發(fā)者在應(yīng)用程序完全啟動并準(zhǔn)備好接收請求之前執(zhí)行一些初始化任務(wù),下面通過實例代碼講解什么是CommandLineRunner以及CommandLineRunner用法,一起看看吧
    2025-08-08
  • maven依賴傳遞和依賴沖突原理

    maven依賴傳遞和依賴沖突原理

    這篇文章主要介紹了maven依賴傳遞和依賴沖突原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • Java數(shù)據(jù)類型之引用數(shù)據(jù)類型解讀

    Java數(shù)據(jù)類型之引用數(shù)據(jù)類型解讀

    這篇文章主要介紹了Java數(shù)據(jù)類型之引用數(shù)據(jù)類型,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 深入淺析HashMap key和value能否為null

    深入淺析HashMap key和value能否為null

    HashMap的key和value可為null,線程不安全,HashTable的key和value均不可為null,線程安全,ConcurrentHashMap在多線程場景下使用,key和value也不能為null,還對它們進(jìn)行了測試和底層代碼分析,本文介紹HashMap key和value能否為null,感興趣的朋友跟隨小編一起看看吧
    2025-04-04
  • spring boot整合log4j2及MQ消費(fèi)處理系統(tǒng)日志示例

    spring boot整合log4j2及MQ消費(fèi)處理系統(tǒng)日志示例

    這篇文章主要為大家介紹了spring boot整合log4j2及MQ消費(fèi)處理系統(tǒng)日志的示例過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • Java Swing JTextArea文本區(qū)域的實現(xiàn)示例

    Java Swing JTextArea文本區(qū)域的實現(xiàn)示例

    這篇文章主要介紹了Java Swing JTextArea文本區(qū)域的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • 深入理解java自旋鎖

    深入理解java自旋鎖

    這篇文章主要介紹了如何深入理解java自旋鎖,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,下面和小編來一起學(xué)習(xí)下吧
    2019-05-05
  • SpringBoot中使用@Async實現(xiàn)異步任務(wù)調(diào)用詳解

    SpringBoot中使用@Async實現(xiàn)異步任務(wù)調(diào)用詳解

    這篇文章主要介紹了SpringBoot中使用@Async實現(xiàn)異步任務(wù)調(diào)用詳解,一個可以無需等待被調(diào)用函數(shù)的返回值就讓操作繼續(xù)進(jìn)行的方法(來自百度百科),即程序在順序執(zhí)行時,不等待異步調(diào)用的語句返回結(jié)果就執(zhí)行后面的程序,需要的朋友可以參考下
    2023-12-12
  • JVM的7種垃圾回收器(小結(jié))

    JVM的7種垃圾回收器(小結(jié))

    這篇文章主要介紹了JVM的7種垃圾回收器(小結(jié)),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10

最新評論