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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

NOIP 2016【蚯蚓】

發布時間:2023/12/13 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 NOIP 2016【蚯蚓】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

好吧,我承認我是個智障……
這道題一眼看上去就是個堆,然而實際上有單調性。
注意到,如果 \(q = 0\) 的話,將蚯蚓的左右兩邊分開丟進兩個隊列中,則兩個隊列都是單調不增的,因為每次取出的蚯蚓長度單調不增。
對于 \(q \neq 0\),因為除了切開的兩只,所有蚯蚓長度都增加了,我們維護這個增加的值,表示三個隊列(包括初始隊列)中所有的元素都要加上這個值才是真實的長度。但是這樣剛切開的蚯蚓的左右兩邊長度就多增加了 \(q\),所以我們把他們的長度減 \(q\) 再丟進兩個隊列中。這樣就保證了每個元素加上這個元素后就是真實的長度。
至于單調性,和 \(q=0\) 相比,每次只有最小的兩個變得更小,而總體加上一個數是不影響單調性的,所以仍然是單調不增的。
我是個智障是因為我代碼里有這樣一句話:

memset(a+1,-127,sizeof(a));

于是數組越界就炸飛天了,別問我為什么,我該吃藥了……

#include <bits/stdc++.h> using namespace std;#define ll long long #define RG register #define N 7100005inline int gi() {RG int ret; RG char ch;ret=0, ch=getchar();while (ch < '0' || ch > '9')ch=getchar();while (ch >= '0' && ch <= '9')ret=(ret<<3)+(ret<<1)+ch-'0', ch=getchar();return ret; }int a[N],l[N],r[N],ha,hl,hr,ta,tl,tr,now;inline void get() {if (a[ha] > l[hl])if (a[ha] > r[hr])now=a[ha++];elsenow=r[hr++];elseif (l[hl] > r[hr])now=l[hl++];elsenow=r[hr++]; }int main() { // freopen("earthworm.in","r",stdin); // freopen("earthworm.out","w",stdout);int n,m,q,u,v,t,i,inc,le,ri;n=gi(), m=gi(), q=gi(), u=gi(), v=gi(), t=gi();memset(a,-127,sizeof(a));memset(l,-127,sizeof(l));memset(r,-127,sizeof(r));for (i=1; i<=n; ++i)a[i]=gi();sort(a+1,a+n+1,greater <int> ());ha=hl=hr=1, tl=tr=0, ta=n, inc=0, i=1;n+=m;while (m--){get();now+=inc;if (i == t)printf("%d ",now), i=0;le=(ll)now*u/v, ri=now-le;inc+=q, i++;le-=inc, ri-=inc;l[++tl]=le, r[++tr]=ri;}putchar('\n');i=1;while (n--){get();if (i == t)i=0, printf("%d ",now+inc);i++;}return 0; }

轉載于:https://www.cnblogs.com/y142857/p/7650884.html

總結

以上是生活随笔為你收集整理的NOIP 2016【蚯蚓】的全部內容,希望文章能夠幫你解決所遇到的問題。

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