搜尋
首頁後端開發C++使用樹狀數組(離線查詢),將範圍L到R中大於K的元素數量計算出來

使用樹狀數組(離線查詢),將範圍L到R中大於K的元素數量計算出來

在電腦科學領域,我們必須處理大型資料集,其中包括查詢選擇和更新操作。以較低的時間複雜度即時執行這些操作對於開發人員來說是一項具有挑戰性的任務。

使用 Fenwick 樹是解決這些基於範圍的查詢問題的有效方法。

Fenwick Tree 是一種資料結構,可以有效地更新元素並計算表中數字的前綴和。它也稱為二元索引樹。

在本文中,我們將討論如何使用 Fenwick 樹來找出 L 到 R 範圍內大於 K 的元素數量。

輸入輸出場景

假設您有一個包含 N 個元素的數組,並且您想要在數組中找到 L 到 R 範圍內大於 K 的元素數量。

Input: 
arr = {1, 15, 12, 13, 6, 18, 14, 10, 23, 41, 16, 9}
N = 11, K = 17, L = 1, R = 8
Output: 
2

什麼是離線查詢?

離線查詢是對預先決定的資料集執行的查詢操作。換句話說,這些操作僅對那些在處理查詢時沒有進一步修改的資料集執行。

使用芬威克樹

在這裡,我們將使用芬威克樹,它的每個節點都有向量,其中按順序包含數組的所有元素。然後,我們使用二分搜尋來回答每個查詢並計算元素的數量。

  • 建立兩個函數,updateTree() 和total(),分別用於更新和檢索BIT中的前綴和。

  • 接下來,建立另一個函數,該函數將計算 L 到 R 範圍內大於「K」的元素。函數接受輸入值「arr」、「N」、「L」、「R」和「K 」。

  • 計數是用最大範圍N的累加和減去K的累加和來計算的。

為了排除超出範圍的元素,減去L-1的累加和(如果L大於1)。

範例

#include <iostream>
#include <vector>
using namespace std;

// Updating the Fenwick Tree
void updateTree(vector<int>& BIT, int index, int value) {
   while (index < BIT.size()) {
      BIT[index] += value;
      index += index & -index;
   }
}

int total(vector<int>& BIT, int index) {
   int result = 0;
   while (index > 0) {
      result += BIT[index];
      index -= index & -index;
   }
   return result;
}

// Counting the number of elements
int elementsGreaterThanK(vector<int>& arr, int N, int K, int L, int R) {
   vector<int> BIT(N+1, 0);

   for (int i = L; i <= R; i++) {
      updateTree(BIT, arr[i], 1);
   }

   int count = total(BIT, N) - total(BIT, K);
   if (L > 1) {
      count -= total(BIT, L-1);
   }
   return count;
}

int main() {
   vector<int> arr = {0, 5, 2, 3, 6, 8, 7, 1, 8, 4, 6, 9};
   int N = 11; // Total range of values
   int K = 4; // Highest value
   int L = 1; // Start index of the range
   int R = 8; // End index of the range

   int count = elementsGreaterThanK(arr, N, K, L, R);
   cout << "Number of elements greater than " << K << " in the range [" << L << ", " << R << "]: " << count << endl;

   return 0;
}

輸出

Number of elements greater than 4 in the range [1, 8]: 5

替代方法

在這裡,我們將建立一個單獨的向量來儲存查詢。每個查詢由兩個變數組成,indexvalindex 用於儲存陣列中的位置,而val用於儲存該索引處元素的值。這種方法使開發人員能夠執行各種查詢操作。此外,我們使用 BIT 計算每個查詢大於 K 的元素數量。

範例

#include <iostream>
#include <vector>
using namespace std;
struct Query {
   int index;
   int val;
};

void updateTree(vector<int>& BIT, int index, int value) {
   while (index < BIT.size()) {
      BIT[index] += value;
      index += index & -index;
   }
}

int total(vector<int>& BIT, int index) {
   int result = 0;
   while (index > 0) {
      result += BIT[index];
      index -= index & -index;
   }
   return result;
}

vector<int> elementsGreaterThanK(vector<int>& arr, vector<Query>& queries, int K) {
   int N = arr.size();
   vector<int> BIT(N+1, 0);
   vector<int> result;

   for (int i = 0; i < N; i++) {
      updateTree(BIT, i+1, (arr[i] > K) ? 1 : 0);
   }

   for (auto query : queries) {
      if (query.val > K) {
         result.push_back(total(BIT, query.index));
      }
      else {
         result.push_back(0);
      }
   }

   return result;
}

int main() {
   vector<int> arr = {3, 14, 32, 7, 11, 5, 8, 6, 16, 2, 15};
   vector<Query> queries = {{2, 4}, {5, 3}, {3, 6}, {0, 3}};
   int K = 2;

   vector<int> counts = elementsGreaterThanK(arr, queries, K);

   for (int count : counts) {
      cout << "Number of elements greater than " << K << ": " << count << endl;
   }

   return 0;
}

輸出

Number of elements greater than 2: 2
Number of elements greater than 2: 5
Number of elements greater than 2: 3
Number of elements greater than 2: 0

結論

我們可以簡單地從索引 L 到 R 迭代數組,並在每次數組元素大於 K 時加 1,以便找到每個查詢的答案。然而,為了降低時間複雜度,我們使用Fenwick樹來進行此類查詢操作。我們也可以使用線段樹稀疏表來取代Fenwick樹來進行此類查詢操作。

以上是使用樹狀數組(離線查詢),將範圍L到R中大於K的元素數量計算出來的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:tutorialspoint。如有侵權,請聯絡admin@php.cn刪除
C標準模板庫(STL)如何工作?C標準模板庫(STL)如何工作?Mar 12, 2025 pm 04:50 PM

本文解釋了C標準模板庫(STL),重點關注其核心組件:容器,迭代器,算法和函子。 它詳細介紹了這些如何交互以啟用通用編程,提高代碼效率和可讀性t

如何有效地使用STL(排序,查找,轉換等)的算法?如何有效地使用STL(排序,查找,轉換等)的算法?Mar 12, 2025 pm 04:52 PM

本文詳細介紹了c中有效的STL算法用法。 它強調了數據結構選擇(向量與列表),算法複雜性分析(例如,std :: sort vs. std vs. std :: partial_sort),迭代器用法和並行執行。 常見的陷阱

我如何在C中有效處理異常?我如何在C中有效處理異常?Mar 12, 2025 pm 04:56 PM

本文詳細介紹了C中的有效異常處理,涵蓋了嘗試,捕捉和投擲機制。 它強調了諸如RAII之類的最佳實踐,避免了不必要的捕獲塊,並為強大的代碼登錄例外。 該文章還解決了Perf

如何使用C中的移動語義來提高性能?如何使用C中的移動語義來提高性能?Mar 18, 2025 pm 03:27 PM

本文討論了使用C中的移動語義來通過避免不必要的複制來提高性能。它涵蓋了使用std :: Move的實施移動構造函數和任務運算符,並確定了關鍵方案和陷阱以有效

如何在C 20中使用範圍進行更有表現的數據操縱?如何在C 20中使用範圍進行更有表現的數據操縱?Mar 17, 2025 pm 12:58 PM

C 20範圍通過表現力,合成性和效率增強數據操作。它們簡化了複雜的轉換並集成到現有代碼庫中,以提高性能和可維護性。

動態調度如何在C中起作用,如何影響性能?動態調度如何在C中起作用,如何影響性能?Mar 17, 2025 pm 01:08 PM

本文討論了C中的動態調度,其性能成本和優化策略。它突出了動態調度會影響性能並將其與靜態調度進行比較的場景,強調性能和之間的權衡

在C中如何有效地使用RVALUE參考?在C中如何有效地使用RVALUE參考?Mar 18, 2025 pm 03:29 PM

文章討論了在C中有效使用RVALUE參考,以進行移動語義,完美的轉發和資源管理,重點介紹最佳實踐和性能改進。(159個字符)

C的內存管理如何工作,包括新,刪除和智能指針?C的內存管理如何工作,包括新,刪除和智能指針?Mar 17, 2025 pm 01:04 PM

C內存管理使用新的,刪除和智能指針。本文討論了手冊與自動化管理以及智能指針如何防止內存洩漏。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

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

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器