javascript
[BZOJ 1012] [JSOI 2008] 最大数maxnumber
1012: [JSOI2008]最大數(shù)maxnumber
Time Limit:?3 Sec??Memory Limit:?162 MBSubmit:?5094??Solved:?2276
[Submit][Status][Discuss]
Description
現(xiàn)在請(qǐng)求你維護(hù)一個(gè)數(shù)列,要求提供以下兩種操作: 1、 查詢操作。語(yǔ)法:Q L 功能:查詢當(dāng)前數(shù)列中末尾L個(gè)數(shù)中的最大的數(shù),并輸出這個(gè)數(shù)的值。限制:L不超過(guò)當(dāng)前數(shù)列的長(zhǎng)度。 2、 插入操作。語(yǔ)法:A n 功能:將n加上t,其中t是最近一次查詢操作的答案(如果還未執(zhí)行過(guò)查詢操作,則t=0),并將所得結(jié)果對(duì)一個(gè)固定的常數(shù)D取模,將所得答案插入到數(shù)列的末尾。限制:n是非負(fù)整數(shù)并且在長(zhǎng)整范圍內(nèi)。注意:初始時(shí)數(shù)列是空的,沒(méi)有一個(gè)數(shù)。
Input
第一行兩個(gè)整數(shù),M和D,其中M表示操作的個(gè)數(shù)(M <= 200,000),D如上文中所述,滿足(0
Output
對(duì)于每一個(gè)查詢操作,你應(yīng)該按照順序依次輸出結(jié)果,每個(gè)結(jié)果占一行。
Sample Input
5 100A 96
Q 1
A 97
Q 1
Q 2
Sample Output
9693
96 【題解】 這題雖然水,但是我也寫了半個(gè)小時(shí)…… 首先我寫了個(gè)離線的線段樹(shù),因?yàn)橐?shù)首先得計(jì)算A的次數(shù),肯定用離線來(lái)建樹(shù),然后不知為何線段樹(shù)寫跪了TAT 然而比完JSOI我就在常州一中寫了一半線段樹(shù),這時(shí)……ysy大神看到了,就提醒我用單調(diào)隊(duì)列 確實(shí)是這樣= = 單調(diào)隊(duì)列是什么呢?首先它是基于隊(duì)列的,如果一個(gè)元素不可能出現(xiàn)在答案里,那么我們就把他排除掉,最常用的是求max、min值,用到單調(diào)隊(duì)列,維護(hù)單調(diào)上升/下降。 然而我寫完單調(diào)隊(duì)列…… 第一遍WA 第二遍RE 臥槽?于是我果斷把字符讀入改成cin了。。 臥槽?還是RE?我就去看了看黃學(xué)長(zhǎng)(orzhzw)的代碼,看到了一種新的解決這個(gè)的方法。 定義一個(gè)只有一個(gè)元素的數(shù)組 char c[1]; 讀入 scanf("%s",c); 就不怕了~ 有道理!要記下來(lái)…… 然后就A掉了 發(fā)現(xiàn)我剛剛cin沒(méi)過(guò)是因?yàn)榍懊娴膕canf多收了一個(gè)\n進(jìn)去 我是這么寫的scanf("%d%d\n",&.....); 頓時(shí)發(fā)現(xiàn)我傻了…… 順便吐槽下今天的JSOI,被虐的好慘TAT差點(diǎn)爆0 QAQ 看來(lái)還有好多還不會(huì)的……慢慢填坑,三個(gè)月?tīng)?zhēng)取填完吧TAT 1 #include<bits/stdc++.h> 2 using namespace std; 3 int M,D,q[200010],t=0,ans[200010],last=0; 4 int main() { 5 scanf("%d %d\n",&M,&D); 6 while(M--) { 7 char opt1[1]; int opt2; scanf("%s%d",opt1,&opt2); 8 if (opt1[0]=='A') { 9 int i=(last+opt2)%D; 10 q[++t]=i; 11 for (i=t; i>=1; --i) 12 if (ans[i]<q[t]) ans[i]=q[t]; 13 else break; 14 } 15 if (opt1[0]=='Q') { 16 last=ans[t-opt2+1]; 17 printf("%d\n",last); 18 } 19 } 20 return 0; 21 } View Code
差點(diǎn)就忘了貼代碼了QAQ
轉(zhuǎn)載于:https://www.cnblogs.com/TonyNeal/p/bzoj1012.html
總結(jié)
以上是生活随笔為你收集整理的[BZOJ 1012] [JSOI 2008] 最大数maxnumber的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: BZOJ2976 : [Poi2002]
- 下一篇: JS 实现 jQuery的$(func