国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

POJ3264 Balanced Lineup 【線段樹】

2019-11-11 01:54:43
字體:
來源:轉載
供稿:網友

題目鏈接:http://poj.org/PRoblem?id=3264

題意: 有一個長度為 n 的序列,然后有 q 個提問,對于每一個提問,輸入兩個數 L, R,輸出這n個序列中L到R的最大值與最小值的差。

題解: 看上去就是一道線段樹的題目,這兩天剛接觸線段樹,于是寫了一發。題目本身并不難,主要就是需要注意一下細節,其他的基本上就沒有什么問題了。 推薦線段樹好文章:http://blog.csdn.net/metalseed/article/details/8039326

代碼:

#include <cstdio>#include <algorithm>using namespace std;const int size = 200005;struct _seg { int l, r; int mx, mn;} seg[size];int n, q, peop[size];void build(int x, int y, int num) { seg[num].l = x; seg[num].r = y; if(x == y) { seg[num].mx = peop[x]; seg[num].mn = peop[y]; } else { build(x, (x+y)/2, num*2); build((x+y)/2+1, y, num*2+1); seg[num].mn = min(seg[num*2].mn, seg[num*2+1].mn); seg[num].mx = max(seg[num*2].mx, seg[num*2+1].mx); }}const int inf = 1 << 26;int resMn = inf, resMx = -inf;void query(int x, int y, int num) { if(x <= seg[num].l && y >= seg[num].r) { resMn = min(resMn, seg[num].mn); resMx = max(resMx, seg[num].mx); return ; } int mid = (seg[num].l+seg[num].r) >> 1; if(y <= mid) query(x, y, num*2); else if(x > mid) query(x, y, num*2+1); else { query(x, y, num*2); query(x, y, num*2+1); }}int main() { // freopen("POJ3264.in", "r", stdin); scanf("%d %d", &n, &q); for ( int i = 1; i <= n; i ++ ) scanf("%d", &peop[i]); build(1, n, 1); for ( int i = 1; i <= q; i ++ ) { int x, y; resMn = inf; resMx = -inf; scanf("%d %d", &x, &y); query(x, y, 1); int ans = resMx-resMn; printf("%d/n", ans); } return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 甘德县| 敦化市| 安图县| 澄迈县| 铜山县| 万荣县| 象州县| 开平市| 乃东县| 昌平区| 岳普湖县| 陆丰市| 碌曲县| 乌兰浩特市| 翁牛特旗| 肇源县| 巢湖市| 洞头县| 扎兰屯市| 夏河县| 乐安县| 板桥市| 临泉县| 龙门县| 伊吾县| 桑植县| 贵定县| 靖安县| 福鼎市| 清镇市| 甘南县| 滨州市| 白玉县| 若尔盖县| 曲水县| 玛曲县| 平阴县| 新兴县| 页游| 额济纳旗| 姜堰市|