首页 > 其他分享 >P1486

P1486

时间:2024-09-10 19:46:14浏览次数:17  
标签:node P1486 int else ans include id

偷懒的新方法

#include<cstdio>  
#include<iostream>  
#include<ext/pb_ds/assoc_container.hpp>  
#include<ext/pb_ds/tree_policy.hpp>  
using namespace __gnu_pbds;  
using namespace std;  
struct node{  
   int v,id;  
   node(int a,int b){v=a;id=b;}  
   bool operator >(node b) const  
   {return v==b.v?id>b.id:v>b.v;}  
};  
tree<node,null_type,greater<node>,rb_tree_tag,tree_order_statistics_node_update> T,TE;  
int main(){  
   int n,m,k,s=0,q,ans=0;  
   char c[10];  
   scanf("%d%d",&n,&m);  
   while(n--){  
       cin>>c[0];scanf("%d",&k);  
       if(*c=='I') {k+=s;if(k>=m) T.insert(node(k,n));}  
       else if(*c=='A') m-=k,s-=k;  
       else if(*c=='S'){  
           m+=k,s+=k;  
           T.split(node(m,-1),TE);  
           ans+=TE.size();  
       }  
       else if(*c=='F')      
           printf(k>T.size()?"-1\n":"%d\n",T.find_by_order(k-1)->v-s);  
   }  
   printf("%d\n",ans);  
   return 0;  
}

标签:node,P1486,int,else,ans,include,id
From: https://www.cnblogs.com/zan-mei-tai-yang/p/18407050

相关文章

  • P1486 [NOI2004] 郁闷的出纳员
    P1486[NOI2004]郁闷的出纳员有两种思路,均使用fhq-treap实现维护一个变量delta表示全局偏移量,对于新插入的数减去偏移量。使用fhq-treap,可以分裂出<mid的部分,直接丢掉。直接用fhq-treap维护一个类似于线段树的懒标记,每次放在根上即可。方法1#include<iostream>#include<r......