nyoj119 士兵殺敵(三) ST演算法和線段樹

2021-07-31 10:22:01 字數 1260 閱讀 2153

時間限制:

2000

ms  |  記憶體限制:

65535

kb難度:

5 描述

南將軍統率著n個士兵,士兵分別編號為1~n,南將軍經常愛拿某一段編號內殺敵數最高的人與殺敵數最低的人進行比較,計算出兩個人的殺敵數差值,用這種方法一方面能鼓舞殺敵數高的人,另一方面也算是批評殺敵數低的人,起到了很好的效果。

所以,南將軍經常問軍師小工第i號士兵到第j號士兵中,殺敵數最高的人與殺敵數最低的人之間軍功差值是多少。

現在,請你寫乙個程式,幫小工回答南將軍每次的詢問吧。

注意,南將軍可能詢問很多次。

輸入

只有一組測試資料

第一行是兩個整數n,q,其中n表示士兵的總數。q表示南將軍詢問的次數。(1

輸出對於每次詢問,輸出第m號士兵到第n號士兵之間所有士兵殺敵數的最大值與最小值的差。

樣例輸入

5 2

1 2 6 9 3

1 22 4

樣例輸出

1

7

st演算法詳解

#include #include #include using namespace std;

const int max_n = 100000 + 2;

int n;

int dp_max[max_n][20];//dp[i][j]記錄從第i個數開始的2^j個數中的最大值

int dp_min[max_n][20];

void solve()dat[max_n << 2];

int min, max;

void build(int l, int r, int rt)

int mid = (l + r) >> 1;

build(lch);

build(rch);

dat[rt].max_ = max(dat[rt << 1].max_, dat[rt << 1 | 1].max_);

dat[rt].min_ = min(dat[rt << 1].min_, dat[rt << 1 | 1].min_);

}void query(int a, int b, int l, int r, int rt)

int mid = (l + r) >> 1;

if(b <= mid) else if(a > mid) else

}int main()

return 0;

}

NYOJ119 士兵殺敵(三)

題目分析 這道題用的rmq演算法 range maximum minimum query 這裡做了幾點優化。1 定義dpmax和dpmin時,為什麼17寫在前面,因為記憶體中資料是按行連續的存的,所以初始化dpmax 0 和dpmin 0 相關資料時,可以直接用memcpy。2 所有的求2的方冪的操...

NYOJ 119士兵殺敵(三)

時間限制 2000 ms 記憶體限制 65535 kb 難度 5 描述 南將軍統率著n個士兵,士兵分別編號為1 n,南將軍經常愛拿某一段編號內殺敵數最高的人與殺敵數最低的人進行比較,計算出兩個人的殺敵數差值,用這種方法一方面能鼓舞殺敵數高的人,另一方面也算是批評殺敵數低的人,起到了很好的效果。所以,...

nyoj119士兵殺敵(三)

時間限制 2000 ms 記憶體限制 65535 kb 難度 5 描述 南將軍統率著n個士兵,士兵分別編號為1 n,南將軍經常愛拿某一段編號內殺敵數最高的人與殺敵數最低的人進行比較,計算出兩個人的殺敵數差值,用這種方法一方面能鼓舞殺敵數高的人,另一方面也算是批評殺敵數低的人,起到了很好的效果。所以,...