如何高效實現二維樹狀數組

一、樹狀數組的介紹

樹狀數組,又叫二叉索引樹,是一種數據結構,用於高效地進行單點更新和區間查詢。樹狀數組主要用於處理靜態或動態數組的前綴和,即快速求出一個數組前綴中所有元素的和。

樹狀數組可以將普通數組中的前綴和轉化為數據結構中的前綴和,這樣就可以快速查詢區間和,並且支持快速單點修改操作。樹狀數組的優點在於其空間複雜度低,實現簡單,而且複雜度都是 O(log n) 級別,因此廣泛應用於各類問題的求解。

二、二維樹狀數組的原理

對於二維的情況,可以將樹狀數組中的一維數組再當成樹狀數組處理,建立起二維樹狀數組,用於處理二維數組的前綴和,即可以快速查詢二維數組中矩形區間的和等問題。二維樹狀數組的建立和查詢都與一維樹狀數組類似,只是需要對於兩個維度分別進行處理。具體實現時,可以將二維數組中的行和列都進行處理,分別建立兩個一維樹狀數組。這樣,在進行矩形區間查詢時,則可以將其轉化為四個一維區間查詢問題。

三、如何高效實現二維樹狀數組

1. 初始化和更新操作

int lowbit(int x) {
    return x & -x; // 求 x 的二進位中最低位的 1 所對應的值
}

void update2D(int x, int y, int k) {
    for (int i = x; i <= n; i += lowbit(i)) {
        for (int j = y; j <= m; j += lowbit(j)) {
            c[i][j] += k;
        }
    }
}

對於二維樹狀數組的初始化和更新操作,同樣需要使用 lowbit 函數來區分每一個區間。在此,我們定義 lowbit 函數為求一個二進位數中末尾 1 的位置,得到的結果即為取余時當前區間的長度。

2. 查詢操作

int query2D(int x, int y) {
    int res = 0;
    for (int i = x; i > 0; i -= lowbit(i)) {
        for (int j = y; j > 0; j -= lowbit(j)) {
            res += c[i][j];
        }
    }
    return res;
}

int query2DRange(int x1, int y1, int x2, int y2) {
    return query2D(x2, y2) - query2D(x2, y1 - 1) - query2D(x1 - 1, y2) + query2D(x1 - 1, y1 - 1);
}

對於二維樹狀數組的查詢操作,需要進行一個四個區間的操作。在此,我們需要兩個一維樹狀數組 c1 和 c2 分別維護行和列方向的前綴和,然後可以通過對四個點的坐標進行四個區間的加減計算得到對應的矩陣區間和。

四、總結

二維樹狀數組是一種十分實用的數據結構,可以方便地處理二維數組的前綴和和矩形區間查詢等問題。在實現時,需要注意橫縱坐標的區分,以及維護兩個一維樹狀數組分別用於維護行和列的前綴和,然後再進行四個區間的加減匯總操作。在實際應用中,二維樹狀數組能夠較為高效地解決一些問題,因此在需要處理二維數組的前綴和等問題時,可以考慮使用二維樹狀數組。

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

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

相關推薦

  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • Python去掉數組的中括弧

    在Python中,被中括弧包裹的數據結構是列表,列表是Python中非常常見的數據類型之一。但是,有些時候我們需要將列表展開成一維的數組,並且去掉中括弧。本文將為大家詳細介紹如何用…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python繪製樹狀圖

    本文將從多個方面詳細闡述Python如何繪製樹狀圖。樹狀圖展示了一個層級結構,常用於表示組織結構、家譜、關係圖等。Python作為一種高級編程語言,具有豐富的可視化庫,有許多方法可…

    編程 2025-04-29
  • Python二維數組對齊輸出

    本文將從多個方面詳細闡述Python二維數組對齊輸出的方法與技巧。 一、格式化輸出 Python中提供了格式化輸出的方法,可以對輸出的字元串進行格式化處理。 names = [‘A…

    編程 2025-04-29
  • Java創建一個有10萬個元素的數組

    本文將從以下方面對Java創建一個有10萬個元素的數組進行詳細闡述: 一、基本介紹 Java是一種面向對象的編程語言,其強大的數組功能可以支持創建大規模的多維數組以及各種複雜的數據…

    編程 2025-04-28
  • Python數組隨機分組用法介紹

    Python數組隨機分組是一個在數據分析與處理中常用的技術,它可以將一個大的數據集分成若干組,以便於進行處理和分析。本文將從多個方面對Python數組隨機分組進行詳細的闡述,包括使…

    編程 2025-04-28
  • Python數組索引位置用法介紹

    Python是一門多用途的編程語言,它有著非常強大的數據處理能力。數組是其中一個非常重要的數據類型之一。Python支持多種方式來操作數組的索引位置,我們可以從以下幾個方面對Pyt…

    編程 2025-04-28
  • Python語言數組從大到小排序符號的用法介紹

    當我們使用Python進行編程的時候,經常需要對數組進行排序從而使數組更加有序,而數組的排序方式有很多,其中從大到小排序符號是一種常見的排序方式。本文將從多個方面對Python語言…

    編程 2025-04-28

發表回復

登錄後才能評論