資料結構 樹狀陣列的幾種用法

2022-05-05 20:51:14 字數 869 閱讀 8561

單點修改

區間修改

單點查詢

區間查詢

洛谷p3374:

洛谷p3368:

洛谷p3374:

#includeusing

namespace

std;

intn,m;

int tree[2000010

];int lowbit(int

k)void add(int x,intk)}

int sum(int

x)

return

ans;

}int

main()

for(int i=1;i<=m;i++)

}

view code

洛谷p3368:

#includeusing

namespace

std;

intn,m;

int tree[500010

];int num[500010

];int lowbit(int

k)void add(int x,intk)}

int sum(int

x)

return

ans;

}int

main()

if(a==2

) }}

view code

原來就上過一遍這個了

但是當時沒有弄懂二進位制和lowbit這些關係啥的

導致並不是太懂

現在再上一遍到是水到渠成了

資料結構 樹狀陣列

區間資訊的維護與查詢專題 樹狀陣列 1.問題 動態連續和查詢問題。給定乙個n個元素的陣列a1,a2,an,你的任務是設計乙個資料結構,支援以下兩種操作。add x,d 操作 讓ax增加d.query l,r 計算al al 1 ar.對普通陣列進行 一次修改或 特定區間 求和,時間複雜度為o n n...

資料結構 樹狀陣列

原陣列 字首和 範圍和 原陣列更改陣列元素在求和效率較低,引入樹狀陣列 假設原陣列a 樹狀陣列c 樹狀陣列 的三種操作 1.lowbit 子葉數 二進位制最低位的1代表多少 實現 int lowbit int n 求 lowbit x returnx x 2.update a i k 假設a i 是...

資料結構 樹狀陣列

講到了線段樹,那就順便講講樹狀陣列吧。假設乙個長度為 12 的線段樹,構建結果如下 在區間求和問題上,在葉子節點,顯然劃線部分的值可以由父親節點 左端葉子節點得到。那麼,這部分資訊就是冗餘的,沒有儲存的必要。同理,可以推導出所有冗餘的部分如下 那麼,去除冗餘部分後的結果如下 給每乙個節點乙個編號。我...