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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

2017.2.12【初中部 GDKOI】模拟赛B组 T4:pot

發布時間:2025/4/14 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2017.2.12【初中部 GDKOI】模拟赛B组 T4:pot 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

pot
Description

這個假期,小h在自家院子里種了許多花,它們圍成了一個圈,從1…n編號(n<=100000),小h 對每盆花都有一個喜好值xi,(-1000<=xi<=1000),小h現在覺得這樣一成不變很枯燥,于是他做了m(m<=100000)個改動,每次把第ki盤花改成喜好值為di的花,然后小h要你告訴他,在這個花圈中,連續的最大喜好值是多少。

Input

第一行,n,花盆的數量
第二行,n個數,表示對于每盆花的喜好值。
第三行:m, 改動的次數
以下m行,每行兩個數ki 和di 。

Output

M行,每一行對應一個更改,表示連續的最大喜好值,且不能整圈都選。(注意:是在圈上找)

Sample Input

5

3 -2 1 2 -5

4

2 -2

5 -5

2 -4

5 -1

Sample Output

4

4

3

5

題解:
對于20分,當然是用一個暴力過去啦~~~
對于30分,用O(nm)的動態規劃,再加上卡常數就好了。
對于100分,此題滿分做法涉及到線段樹,不懂的可以去了解一下。
本題題意是數形成一個環狀,又說了不可以全部數選擇。那么,我們只需要求出1到n內最大的子區間和;從兩邊開始選的最大子區間和;1到n內最小的子區間和;從兩邊開始選的最小子區間和。因為我們要求出這樣的東東:




那么,最優答案就是sum(表示數環的總和)-min或max。這時,我們用線段樹來做這些操作,然后大體細節就好好看題,筆玩一下就可以推出線段樹維護的規律。
來給個偽程序來維護max和min的操作:

{v為當前樹的深度} tree[v].sum:=tree[v*2].sum+tree[v*2+1].sum;{求sum值} tree[v].max:=max(max(tree[v*2].max,tree[v*2+1].max),tree[v*2].rgss+tree[v*2+1].lgss);{求max的值} tree[v].lgss:=tree[v*2].lgss;{左邊的maxlgss值} tree[v].rgss:=tree[v*2+1].rgss;{右邊的maxrgss值} tree[v].min:=min(min(tree[v*2].min,tree[v*2+1].min),tree[v*2].mrgss+tree[v*2+1].mlgss);{求min的值} tree[v].mlgss:=tree[v*2].mlgss{求左邊的minlgss值}; tree[v].mrgss:=tree[v*2+1].mrgss{求右邊的minrgss值};if(tree[v*2].lgss<tree[v*2].sum+tree[v*2+1].lgss) thenbegintree[v].lgss:=tree[v*2].sum+tree[v*2+1].lgss;end;if(tree[v*2+1].rgss<tree[v*2+1].sum+tree[v*2].rgss) thenbegintree[v].rgss:=tree[v*2+1].sum+tree[v*2].rgss;end;if(tree[v*2].mlgss>tree[v*2].sum+tree[v*2+1].mlgss) thenbegintree[v].mlgss:=tree[v*2].sum+tree[v*2+1].mlgss;end;if(tree[v*2+1].mrgss>tree[v*2+1].sum+tree[v*2].mrgss) thenbegintree[v].mrgss:=tree[v*2+1].sum+tree[v*2].mrgss;end;

解答問題1:lgss和rgss有何用?答:這個可以時刻維護max的求值,具體維護法筆玩一下,這里不多說。(因為要說明就要畫圖)
解答問題2:如何判斷有沒有全部選。答:這是廢話,只需要判斷max值與sum值相不相等。
解答問題3:為什么sum要在樹內做。答:這可以更好地去維護maxlgss、maxrgss、minlgss、minrgss的操作,當然時間會更快的問題我就不確定了。
解答問題4:線段樹怎么做。答:自己研究。

標程:

typenew=recordmax:longint;lgss:longint;rgss:longint;min:longint;mlgss:longint;mrgss:longint;sum:longint;end;vari,j,k,l,n,m,t,r,x,gb,ans:longint;a:array[0..1000000] of longint;tree:array[0..1000000] of new;bz:boolean; function max(x,y:longint):longint; beginif x>y then exit(x)else exit(y); end; function min(x,y:longint):longint; beginif x<y then exit(x)else exit(y); end; procedure maketree(x,st,en:longint); varm:longint; begintree[x].max:=-50001;tree[x].min:=50001;tree[x].lgss:=-50001;tree[x].rgss:=-50001;tree[x].mlgss:=50001;tree[x].mrgss:=-50001;if st=en thenbeginexit;endelsebeginm:=(st+en) div 2;maketree(x+x,st,m);maketree(x+x+1,m+1,en);end; end; procedure changenumber(v,x,l,r:longint); vari,j,mid:longint; beginif l=r thenbegintree[v].max:=gb;tree[v].min:=gb;tree[v].lgss:=gb;tree[v].rgss:=gb;tree[v].mlgss:=gb;tree[v].mrgss:=gb;tree[v].sum:=gb;exit;end;mid:=(r+l) div 2;if x>mid thenbeginchangenumber(v*2+1,x,mid+1,r);endelseif x<=mid thenbeginchangenumber(v*2,x,l,mid);end;tree[v].sum:=tree[v*2].sum+tree[v*2+1].sum;tree[v].max:=max(max(tree[v*2].max,tree[v*2+1].max),tree[v*2].rgss+tree[v*2+1].lgss);tree[v].lgss:=tree[v*2].lgss;tree[v].rgss:=tree[v*2+1].rgss;tree[v].min:=min(min(tree[v*2].min,tree[v*2+1].min),tree[v*2].mrgss+tree[v*2+1].mlgss);tree[v].mlgss:=tree[v*2].mlgss;tree[v].mrgss:=tree[v*2+1].mrgss;if(tree[v*2].lgss<tree[v*2].sum+tree[v*2+1].lgss) thenbegintree[v].lgss:=tree[v*2].sum+tree[v*2+1].lgss;end;if(tree[v*2+1].rgss<tree[v*2+1].sum+tree[v*2].rgss) thenbegintree[v].rgss:=tree[v*2+1].sum+tree[v*2].rgss;end;if(tree[v*2].mlgss>tree[v*2].sum+tree[v*2+1].mlgss) thenbegintree[v].mlgss:=tree[v*2].sum+tree[v*2+1].mlgss;end;if(tree[v*2+1].mrgss>tree[v*2+1].sum+tree[v*2].mrgss) thenbegintree[v].mrgss:=tree[v*2+1].sum+tree[v*2].mrgss;end; end; begin//assign(input,'xds.in');reset(input);//assign(output,'xds.out');rewrite(output);readln(n);maketree(1,1,n);for i:=1 to n dobeginread(a[i]);end;for i:=1 to n dobegingb:=a[i];changenumber(1,i,1,n);end;readln(m);for k:=1 to m dobeginreadln(l,r);gb:=r;changenumber(1,l,1,n);if(tree[1].max=tree[1].sum) thenbeginwriteln(tree[1].max-tree[1].min);continue;end;if(tree[1].max>=tree[1].sum-tree[1].min) thenbeginwriteln(tree[1].max);continue;end;if(tree[1].max<tree[1].sum-tree[1].min) thenbeginwriteln(tree[1].sum-tree[1].min);end;end; end.

轉載于:https://www.cnblogs.com/RainbowCrown/p/11148449.html

總結

以上是生活随笔為你收集整理的2017.2.12【初中部 GDKOI】模拟赛B组 T4:pot的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 乱色熟女综合一区二区三区 | 一级特黄特色的免费大片视频 | 欧洲亚洲天堂 | 国产精品99久久久久久动医院 | 农村少妇 | 亚洲一区二区影院 | 国产丝袜第一页 | 成人动漫视频在线观看 | 久久久精品人妻av一区二区三区 | 国产探花在线精品一区二区 | 亚洲精品少妇久久久久久 | 亚洲国产精品成人av | 欧美在线视频a | 污导航在线观看 | 国产成人精品久久二区二区 | 极品美女销魂一区二区三区 | 国产人妖ts | 一区二区三区国产精品 | 欧美日韩在线视频免费播放 | 777在线视频 | 97视频一区 | 成人性做爰aaa片免费 | 欧美美女在线 | 在线视频福利 | 亚洲av成人精品午夜一区二区 | 成人激情综合网 | 国产一区日韩 | 欧美色图五月天 | 国产在线观看免费高清 | 国产激情图片 | 69久久精品无码一区二区 | 欧美视频综合 | 天天干天天做 | 青青草午夜 | 91大神在线观看视频 | 无码成人精品区在线观看 | 欧美欧美欧美 | 亚洲黄色录像 | 免费网站在线高清观看 | 被警察猛c猛男男男 | 精品亚洲一区二区三区 | 色婷婷亚洲一区二区三区 | 朝桐光在线视频 | 黄色成人一级片 | 日日操狠狠操 | 中国一级特黄真人毛片免费观看 | www.色人阁.com | 干成人网| 小视频在线观看 | www.亚洲国产| 亚洲成人国产 | 91国在线视频 | 91蝌蚪| 精品久久久久久亚洲精品 | 亚洲丁香色 | juliaann欧美二区三区 | av污在线观看| 亚洲综合五区 | 97人人爽人人| 黄色一级片在线播放 | 男女羞羞在线观看 | 天天摸天天干 | 无人在线观看的免费高清视频 | 吃奶av| 精品日韩制服无码久久久久久 | 亚洲黄色av | 色玖玖综合 | 日韩人妻无码一区二区三区99 | 国产美女性生活 | 一区二区韩国 | 丁香婷婷网 | 久久免费播放视频 | av色欲无码人妻中文字幕 | 99ri国产 | 在线观看成人免费视频 | 大地资源二中文在线影视观看 | 国产影视一区二区三区 | 欧美一区综合 | 久久丫精品国产亚洲av不卡 | 色av综合网 | 人人澡人人添 | 美女让男人捅 | 色播综合网 | 国产原创一区 | 不卡视频在线 | 男女搞黄网站 | 天堂网视频在线 | 污污视频免费观看 | 国产精品三区在线观看 | 在线成人免费电影 | 在线视频欧美一区 | 毛片1000部免费看 | 麻豆亚洲av熟女国产一区二 | 激情综合五月网 | 国产一区二区三区电影在线观看 | 亚色一区 | 国产91高清 | 欧美性受xxxx黑人xyx | 夫妻黄色片 |