時間限制:
1000 ms | 記憶體限制:
65535 kb
難度:5 描述
南將軍手下有n個士兵,分別編號1到n,這些士兵的殺敵數都是已知的。
小工是南將軍手下的軍師,南將軍經常想知道第m號到第n號士兵的總殺敵數,請你幫助小工來回答南將軍吧。
南將軍的某次詢問之後士兵i可能又殺敵q人,之後南將軍再詢問的時候,需要考慮到新增的殺敵數。
輸入
只有一組測試資料
第一行是兩個整數n,m,其中n表示士兵的個數(1
輸出對於每次查詢,輸出乙個整數r表示第m號士兵到第n號士兵的總殺敵數,每組輸出佔一行
樣例輸入
5 61 2 3 4 5
query 1 3
add 1 2
query 1 3
add 2 3
query 1 2
query 1 5
樣例輸出
688
還是扔模板,加乙個update函式更新資料:
void update(int o,int l,int r,int x, int y)
int mid=(l+r)>>1;
if(x<=mid)
update(o<<1,l,mid,x,y);
else
update(o<<1|1,mid+1,r,x,y);
tree[o].sum=tree[o<<1].sum+tree[o<<1|1].sum;
}
ac code:
#include#include#include#include#include#include#include#includeusing namespace std;
struct node
tree[1000010<<2];
void build(int o,int l,int r)
int mid=(l+r)>>1;
build(o<<1,l,mid);
build(o<<1|1,mid+1,r);
tree[o].sum=tree[o<<1].sum+tree[o<<1|1].sum;
}void update(int o,int l,int r,int x, int y)
int mid=(l+r)>>1;
if(x<=mid)
update(o<<1,l,mid,x,y);
else
update(o<<1|1,mid+1,r,x,y);
tree[o].sum=tree[o<<1].sum+tree[o<<1|1].sum;
}int querysum(int o,int l,int r,int x,int y)
int main()
return 0;
}
nyoj116 士兵殺敵(二) 線段樹)
時間限制 1000 ms 記憶體限制 65535 kb 難度 5 描述 南將軍手下有n個士兵,分別編號1到n,這些士兵的殺敵數都是已知的。小工是南將軍手下的軍師,南將軍經常想知道第m號到第n號士兵的總殺敵數,請你幫助小工來回答南將軍吧。南將軍的某次詢問之後士兵i可能又殺敵q人,之後南將軍再詢問的時候...
nyoj116 士兵殺敵二(線段樹)
時間限制 1000 ms 記憶體限制 65535 kb 難度 5 描述 南將軍手下有n個士兵,分別編號1到n,這些士兵的殺敵數都是已知的。小工是南將軍手下的軍師,南將軍經常想知道第m號到第n號士兵的總殺敵數,請你幫助小工來回答南將軍吧。南將軍的某次詢問之後士兵i可能又殺敵q人,之後南將軍再詢問的時候...
NYOJ116 士兵殺敵(二) 線段數 單點更新
描述 南將軍手下有n個士兵,分別編號1到n,這些士兵的殺敵數都是已知的。小工是南將軍手下的軍師,南將軍經常想知道第m號到第n號士兵的總殺敵數,請你幫助小工來回答南將軍吧。南將軍的某次詢問之後士兵i可能又殺敵q人,之後南將軍再詢問的時候,需要考慮到新增的殺敵數。輸入 只有一組測試資料 第一行是兩個整數...