日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

[SPOJ] 1043 Can you answer these queries I [GSS1]

發(fā)布時間:2024/10/8 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [SPOJ] 1043 Can you answer these queries I [GSS1] 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

Pro?

  給你一個序列{A[1], A[2], ..., A[N]}.( |A[i]| ≤ 15007 , 1 ≤ N ≤ 50000 )?? ? ?

  給定“查詢”操作的定義如下:?? ? ? ? ?

    Query(x,y) = Max { a[i]+a[i+1]+...+a[j] ; x ≤ i ≤ j ≤ y }.? ? ?

  給出M個查詢,你的程序需要輸出這些查詢的結(jié)果。

Input

? ? ?輸入文件的第一行包含一個整數(shù)n,表示給出的數(shù)的個數(shù);? ? ?

  在第二行,給出N個數(shù)字,表示A[1]到A[n];? ? ?

  第三行包含整數(shù)M,表示詢問的個數(shù);? ? ?

  接下來M行,每行包含兩個數(shù)x和y.

Output

?????????你的程序應(yīng)該輸出M個查詢的結(jié)果,每個查詢結(jié)果占一行。

Sample Input

3?? ?

-1 2 3? ?

1? ?

1 2

?

Sample Output

2

?

Solution

?

這是一道比較基礎(chǔ)的線段樹的練習(xí)題,即詢問區(qū)間最大字段和, 我們可以用線段樹維護4個值,

分別是當(dāng)前區(qū)間從最左端開始的最大子段lmax, 從最右端開始的最大子段rmax,當(dāng)前區(qū)間的最大子段和smax以及當(dāng)前區(qū)間的和sum。

對于每一個詢問,我們可以在自底向上(zkw)的過程中維護3個值,

分別是 當(dāng)前左區(qū)間從最右端開始的最大子段lrans,當(dāng)前有區(qū)間從最左端開始的最大子段rlans,

還有當(dāng)前左區(qū)間和右區(qū)間中的最大子段和subans,最后在lrans + rlans和subans中取 最大值輸出就可以了。

Source

#include <stdio.h> #include <memory.h> const int nmax = 50000;int lmax[(1 << 17) + 18], rmax[(1 << 17) + 18], sum[(1 << 17) + 18], smax[(1 << 17) + 18]; int n, m, l, r, M = 1; int i, lrans, rlans, subans;int max (int a, int b) {return a > b ? a : b; }int query (int l, int r) {subans = lrans = rlans = -nmax;for (l += M - 1, r += M + 1; l ^ r ^ 1; l >>= 1, r >>= 1){if (~l & 1){subans = max (subans, max (smax[l ^ 1], lrans + lmax[l ^ 1]));lrans = max (rmax[l ^ 1], lrans + sum[l ^ 1]);}if ( r & 1){subans = max (subans, max (smax[r ^ 1], rlans + rmax[r ^ 1]));rlans = max (lmax[r ^ 1], rlans + sum[r ^ 1]);}}return max (subans, lrans + rlans); }int main () {freopen ("GSS1.in", "r", stdin);freopen ("GSS1.out", "w", stdout);scanf ("%d", &n);memset (lmax, 0xEF, sizeof (lmax));memset (rmax, 0xEF, sizeof (rmax));memset (sum, 0xEF, sizeof (sum));memset (smax, 0xEF, sizeof (smax));while (M < n) M <<= 1;for (i = 1; i <= n; ++i)scanf ("%d", &lmax[i + M]), sum[i + M] = rmax[i + M] = smax[i + M] = lmax[i + M];for (i = M - 1; i; --i){lmax[i] = max (lmax[i << 1], sum[i << 1] + lmax[(i << 1) + 1]);rmax[i] = max (rmax[(i << 1) + 1], rmax[i << 1] + sum[(i << 1) + 1]);sum[i] = sum[i << 1] + sum[(i << 1) + 1];smax[i] = max (max (smax[i << 1], smax[(i << 1) + 1]), rmax[i << 1] + lmax[(i << 1) + 1]);}scanf ("%d", &m);for (i = 1; i <= m; ++i)scanf ("%d%d", &l, &r), printf ("%d\n", query (l, r));return 0; }

轉(zhuǎn)載于:https://www.cnblogs.com/Neroysq/archive/2011/05/24/2056019.html

總結(jié)

以上是生活随笔為你收集整理的[SPOJ] 1043 Can you answer these queries I [GSS1]的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 在线免费观看一区二区 | 人妻精品久久久久中文字幕69 | 精品无码国产污污污在线观看 | 中国黄色免费 | 国产山村乱淫老妇女视频 | 国产精久久 | 日韩啊啊啊| 亚洲国产aⅴ成人精品无吗 日韩乱论 | 亚洲天堂网一区 | 色哟哟一区二区三区 | 久草免费在线视频观看 | 亚洲伦理网 | 九色婷婷| 成人免费视频国产免费网站 | 激情视频区 | 成人一区二区三区在线 | 欧美国产精品一二三 | 肉丝肉足丝袜一区二区三区 | 一级二级三级黄色片 | 三上悠亚人妻中文字幕在线 | 久久综合久久88 | 中文字幕 日本 | 可以看av的网址 | 日韩sese | 黄色av三级 | 男生尿隔着内裤呲出来视频 | 99热这里是精品 | 精品无码一区二区三区电影桃花 | 伊人久久影院 | 国产又粗又黄的视频 | 91在线观看视频 | 网站黄在线观看 | 999综合网 | 国产女人和拘做受视频免费 | 色爱综合网 | 张柏芝54张无删码视频 | 午夜肉伦伦影院 | av一级免费 | 亚洲精品色图 | 亚洲在线一区二区 | 无人在线观看高清视频 | 重口变态虐黄网站 | xxsm.com| 一区二区三区高清 | 国产一区二区精品在线 | 国产精品99久久免费黑人人妻 | 天天碰免费视频 | 成年人的黄色片 | 91视频在线免费 | 欧美aaaaaa| 在线观看不卡的av | 精品国产视频在线 | 欧美综合在线观看 | 亚洲色图欧美 | 国产福利视频一区 | 在线免费观看高清视频 | 撕开少妇裙子猛然进入 | 成人黄页网站 | 黄色靠逼视频 | 91嫩草欧美久久久九九九 | 亚洲精品动漫在线观看 | 亚洲视频一区二区三区在线观看 | www日韩在线观看 | 九九热在线精品 | 丁香六月婷婷激情 | 天堂8av| 污污内射在线观看一区二区少妇 | 色屁屁网站 | 999午夜| 影音先锋毛片 | 国产精品黄色片 | 精品96久久久久久中文字幕无 | 亚洲国产成人综合 | 黄色片子网站 | 在线国产三级 | 欧美日韩无 | 成人免费毛片网站 | 高清视频在线免费观看 | 欧美日韩在线观看一区二区三区 | 青草精品在线 | 肉丝肉足丝袜一区二区三区 | 中文字幕亚洲视频 | 狠狠的日 | 91精品久久久久久久久中文字幕 | 国产人妻一区二区 | 精品国产自在精品国产精小说 | 蜜桃精品噜噜噜成人av | 国产精品久久无码 | 久久久激情网 | 91手机视频 | 爱吃波客今天最新视频 | 欧美成人女星 | 日韩激情床戏 | 丰满秘书被猛烈进入高清播放在 | 国产成人短视频在线观看 | 国产精品成人aaaa在线 | 日韩一级伦理片 | 久久久久久久久久久综合 | 夜夜嗨av一区二区三区四区 |