NOIP 2016【蚯蚓】
生活随笔
收集整理的這篇文章主要介紹了
NOIP 2016【蚯蚓】
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
好吧,我承認我是個智障……
這道題一眼看上去就是個堆,然而實際上有單調性。
注意到,如果 \(q = 0\) 的話,將蚯蚓的左右兩邊分開丟進兩個隊列中,則兩個隊列都是單調不增的,因為每次取出的蚯蚓長度單調不增。
對于 \(q \neq 0\),因為除了切開的兩只,所有蚯蚓長度都增加了,我們維護這個增加的值,表示三個隊列(包括初始隊列)中所有的元素都要加上這個值才是真實的長度。但是這樣剛切開的蚯蚓的左右兩邊長度就多增加了 \(q\),所以我們把他們的長度減 \(q\) 再丟進兩個隊列中。這樣就保證了每個元素加上這個元素后就是真實的長度。
至于單調性,和 \(q=0\) 相比,每次只有最小的兩個變得更小,而總體加上一個數是不影響單調性的,所以仍然是單調不增的。
我是個智障是因為我代碼里有這樣一句話:
于是數組越界就炸飛天了,別問我為什么,我該吃藥了……
#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【蚯蚓】的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 百度AIG知识图谱部算法实习生面经(已拿
- 下一篇: 反爬机制