當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
[BZOJ 1012] [JSOI 2008] 最大数maxnumber
生活随笔
收集整理的這篇文章主要介紹了
[BZOJ 1012] [JSOI 2008] 最大数maxnumber
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1012: [JSOI2008]最大數maxnumber
Time Limit:?3 Sec??Memory Limit:?162 MBSubmit:?5094??Solved:?2276
[Submit][Status][Discuss]
Description
現在請求你維護一個數列,要求提供以下兩種操作: 1、 查詢操作。語法:Q L 功能:查詢當前數列中末尾L個數中的最大的數,并輸出這個數的值。限制:L不超過當前數列的長度。 2、 插入操作。語法:A n 功能:將n加上t,其中t是最近一次查詢操作的答案(如果還未執行過查詢操作,則t=0),并將所得結果對一個固定的常數D取模,將所得答案插入到數列的末尾。限制:n是非負整數并且在長整范圍內。注意:初始時數列是空的,沒有一個數。
Input
第一行兩個整數,M和D,其中M表示操作的個數(M <= 200,000),D如上文中所述,滿足(0
Output
對于每一個查詢操作,你應該按照順序依次輸出結果,每個結果占一行。
Sample Input
5 100A 96
Q 1
A 97
Q 1
Q 2
Sample Output
9693
96 【題解】 這題雖然水,但是我也寫了半個小時…… 首先我寫了個離線的線段樹,因為要建樹首先得計算A的次數,肯定用離線來建樹,然后不知為何線段樹寫跪了TAT 然而比完JSOI我就在常州一中寫了一半線段樹,這時……ysy大神看到了,就提醒我用單調隊列 確實是這樣= = 單調隊列是什么呢?首先它是基于隊列的,如果一個元素不可能出現在答案里,那么我們就把他排除掉,最常用的是求max、min值,用到單調隊列,維護單調上升/下降。 然而我寫完單調隊列…… 第一遍WA 第二遍RE 臥槽?于是我果斷把字符讀入改成cin了。。 臥槽?還是RE?我就去看了看黃學長(orzhzw)的代碼,看到了一種新的解決這個的方法。 定義一個只有一個元素的數組 char c[1]; 讀入 scanf("%s",c); 就不怕了~ 有道理!要記下來…… 然后就A掉了 發現我剛剛cin沒過是因為前面的scanf多收了一個\n進去 我是這么寫的scanf("%d%d\n",&.....); 頓時發現我傻了…… 順便吐槽下今天的JSOI,被虐的好慘TAT差點爆0 QAQ 看來還有好多還不會的……慢慢填坑,三個月爭取填完吧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
差點就忘了貼代碼了QAQ
轉載于:https://www.cnblogs.com/TonyNeal/p/bzoj1012.html
總結
以上是生活随笔為你收集整理的[BZOJ 1012] [JSOI 2008] 最大数maxnumber的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: BZOJ2976 : [Poi2002]
- 下一篇: 什么是简单的分析SQL注入漏洞