nyoj 123 士兵殺敵(四)

2022-08-29 16:00:35 字數 1212 閱讀 8925

時間限制:2000 ms  |  記憶體限制:65535 kb

難度:5

描述南將軍麾下有百萬精兵,現已知共有m個士兵,編號為1~m,每次有任務的時候,總會有一批編號連在一起人請戰(編號相近的人經常在一塊,相互之間比較熟悉),最終他們獲得的軍功,也將會平分到每個人身上,這樣,有時候,計算他們中的哪乙個人到底有多少軍功就是乙個比較困難的事情,軍師小工的任務就是在南將軍詢問他某個人的軍功的時候,快速的報出此人的軍功,請你編寫乙個程式來幫助小工吧。

假設起始時所有人的軍功都是0.

輸入只有一組測試資料。

每一行是兩個整數t和m表示共有t條指令,m個士兵。(1<=t,m<=1000000)

隨後的t行,每行是乙個指令。

指令分為兩種:

一種形如

add 100 500 55 表示,第100個人到第500個人請戰,最終每人平均獲得了55軍功,每次每人獲得的軍功數不會超過100,不會低於-100。

第二種形如:

query 300 表示南將軍在詢問第300個人的軍功是多少。

輸出對於每次查詢輸出此人的軍功,每個查詢的輸出佔一行。

樣例輸入

4 10

add 1 3 10

query 3

add 2 6 50

query 3

樣例輸出

10

60

**

[張云聰]原創

上傳者張云聰

1 #include 2 #include 34

int c[1000010

],n;56

int lowbit(intn)7

1011

void add(int i,int

t)1218}

1920

int sum(int

n)21

28return

s;29}30

31int

main()

3246

else

47 51}

52return0;

53}54//

樹狀陣列--插線取點

關於插線問點,思路一看**就能懂,就是把a點後面的值全加x,然後把b+1後面的值全減x,這樣就相當於只給[a,b]區間內的值加了x。

ps:關於樹狀陣列,最重要的一點就是,一定要從1開始,不能從0開始,因為lowbit(0)=0,會出現死迴圈。

NYOJ123 士兵殺敵(四)

includeconst int n 1000002 struct tree tree tree n 2 void build int root,int l,int r void insert int root,int b,int e,int v int m tree root left tree ...

NYOJ 123士兵殺敵(四)

時間限制 2000 ms 記憶體限制 65535 kb 難度 5 描述 南將軍麾下有百萬精兵,現已知共有m個士兵,編號為1 m,每次有任務的時候,總會有一批編號連在一起人請戰 編號相近的人經常在一塊,相互之間比較熟悉 最終他們獲得的軍功,也將會平分到每個人身上,這樣,有時候,計算他們中的哪乙個人到底...

nyoj 123 士兵殺敵 四

描述 南將軍麾下有百萬精兵,現已知共有m個士兵,編號為1 m,每次有任務的時候,總會有一批編號連在一起人請戰 編號相近的人經常在一塊,相互之間比較熟悉 最終他們獲得的軍功,也將會平分到每個人身上,這樣,有時候,計算他們中的哪乙個人到底有多少軍功就是乙個比較困難的事情,軍師小工的任務就是在南將軍詢問他...