BZOJ 2002, 弹飞绵羊
来源:互联网 发布:上海期货交易软件下载 编辑:程序博客网 时间:2024/05/16 10:55
Problem
传送门
Mean
输入链上各弹力装置的弹力系数,要求支持修改弹力系数以及查询绵羊被弹几次后弹飞。
Analysis
LCT可做,而且时间复杂度优。
分块虽然慢一些但是编程复杂度比较低。(其实是我不想学LCT……)
两个数组cnt和nxt分别记录处于当前装置时被弹几次后弹出当前块以及弹到后面的什么位置。
分块对细节处理要求比较高,题目中也特别强调了装置编号为0到n-1,需要注意。
Code
#include<cstdio>#include<cmath>const int N=200005;int n,m,i,j,k,len,p,q=1,a[N],l[450],r[450],cnt[N],nxt[N],c[N];int min(int a,int b){return a<b?a:b;}int init(int x){ if(cnt[x]) return cnt[x]; if(x+a[x]>r[c[x]]){ nxt[x]=x+a[x]>n?n:x+a[x]; return cnt[x]=1; } cnt[x]=init(x+a[x])+1; nxt[x]=nxt[x+a[x]]; return cnt[x];}void change(int x,int y){ if(x+y>r[c[x]]) nxt[x]=x+y>n?n:x+y,cnt[x]=1; else nxt[x]=nxt[x+y],cnt[x]=cnt[x+y]+1; for(int i=l[c[x]];i<x;i++) cnt[i]=0; for(int i=l[c[x]];i<x;i++) if(!cnt[i]) init(i);}int query(int x){ if(x>=n) return 0; return cnt[x]+query(nxt[x]);}int main(){ scanf("%d",&n); for(i=0;i<n;i++) scanf("%d",&a[i]); len=(int)pow(n,0.5); while(p<n) l[q]=p,r[q++]=min((p+=len)-1,n-1); for(int i=1;i<q;i++) for(int j=l[i];j<=r[i];j++) c[j]=i; for(int i=0;i<n;i++) if(!cnt[i]) init(i); scanf("%d",&m); while(m--){ scanf("%d%d",&i,&j); if(i==2){ scanf("%d",&k); change(j,a[j]=k); }else printf("%d\n",query(j)); } return 0;}
0 0
- BZOJ 2002, 弹飞绵羊
- Bzoj 2002 弹飞绵羊
- bzoj 2002 弹飞绵羊
- BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊
- bzoj 2002: [Hnoi2010]Bounce 弹飞绵羊
- BZOJ 2002 HNOI2010 弹飞绵羊 分块
- 【BZOJ 2002】 [Hnoi2010]Bounce 弹飞绵羊
- 【动态树】 BZOJ 2002 弹飞绵羊
- BZOJ-2002-Bounce弹飞绵羊-分块
- bzoj 2002: [Hnoi2010]Bounce 弹飞绵羊
- bzoj-2002 Bounce 弹飞绵羊
- 【BZOJ】2002 弹飞绵羊 分块
- BZOJ 2002 Hnoi2010 弹飞绵羊 分块
- bzoj 2002 Bounce 弹飞绵羊
- bzoj 2002: [Hnoi2010]Bounce 弹飞绵羊
- BZOJ 2002 Bounce 弹飞绵羊 [Hnoi2010]
- bzoj 2002: [Hnoi2010]Bounce 弹飞绵羊
- bzoj 2002: [Hnoi2010]Bounce 弹飞绵羊
- SPRING-MVC访问静态文件,如jpg,js,css
- 欢迎使用CSDN-markdown编辑器
- 有志者事竟成
- 大蟒蛇之旅
- 【树状数组】[BZOJ1878]HH的项链
- BZOJ 2002, 弹飞绵羊
- Linux IPC之Socket网络编程服务器的负载均衡
- Linux Host\network\ifcfg-eth0 等网络相关的配置文件
- [洛谷P1262]间谍网络
- java bean、List、数组、map和Json的相互转化
- React小坑
- C#入门8.1——方法的声明及调用(1)
- 剑指Offer_17_树的子结构
- 0202 - 应用组件 - Intent 和 Intent 过滤器