Description

某天,Lostmonkey发明了一种超级弹力装置,为了在 他的绵羊朋友面前显摆,他邀请小绵羊一起玩个游戏。游戏一开始,Lostmonkey在地上沿着一条直线摆上n个装置,每个装置设定初始弹力系数ki,当 绵羊达到第i个装置时,它会往后弹ki步,达到第i+ki个装置,若不存在第i+ki个装置,则绵羊被弹飞。绵羊想知道当它从第i个装置起步时,被弹几次 后会被弹飞。为了使得游戏更有趣,Lostmonkey可以修改某个弹力装置的弹力系数,任何时候弹力系数均为正整数。

Input

第 一行包含一个整数n,表示地上有n个装置,装置的编号从0到n-1,接下来一行有n个正整数,依次为那n个装置的初始弹力系数。第三行有一个正整数m,接 下来m行每行至少有两个数i、j,若i=1,你要输出从j出发被弹几次后被弹飞,若i=2则还会再输入一个正整数k,表示第j个弹力装置的系数被修改成 k。对于20%的数据n,m<=10000,对于100%的数据n<=200000,m<=100000

Output

对于每个i=1的情况,你都要输出一个需要的步数,占一行。

Sample Input

4
1 2 1 1
3
1 1
2 1 1
1 1

Sample Output

2
3

解题思路:

LCT,很显然要让 i 与 i 能到的点连边,yy一个不存在的点n+1,让所有点与它连边表示弹飞。

更改时先Cut后Link

最后查询时将n+1与x路径提取,查询重量即可(注意要-1^_^)

代码:

 #include<cstdio>
#include<cstring>
#include<algorithm>
#define lll tr[spc].ch[0]
#define rrr tr[spc].ch[1]
#define ls ch[0]
#define rs ch[1]
const int N=;
struct trnt{
int ch[];
int lzt;
int fa;
int wgt;
bool anc;
}tr[N];
int nx[N];
int n,m;
bool whc(int spc)
{
return tr[tr[spc].fa].rs==spc;
}
void pushup(int spc)
{
tr[spc].wgt=tr[lll].wgt+tr[rrr].wgt+;
return ;
}
void trr(int spc)
{
if(!spc)
return ;
std::swap(lll,rrr);
tr[spc].lzt^=;
return ;
}
void pushdown(int spc)
{
if(tr[spc].lzt)
{
tr[spc].lzt=;
trr(lll);
trr(rrr);
}
return ;
}
void recal(int spc)
{
if(!tr[spc].anc)
recal(tr[spc].fa);
pushdown(spc);
return ;
}
void rotate(int spc)
{
int f=tr[spc].fa;
bool k=whc(spc);
tr[f].ch[k]=tr[spc].ch[!k];
tr[spc].ch[!k]=f;
if(tr[f].anc)
{
tr[spc].anc=;
tr[f].anc=;
}else
tr[tr[f].fa].ch[whc(f)]=spc;
tr[spc].fa=tr[f].fa;
tr[f].fa=spc;
tr[tr[f].ch[k]].fa=f;
pushup(f);
pushup(spc);
return ;
}
void splay(int spc)
{
recal(spc);
while(!tr[spc].anc)
{
int ft=tr[spc].fa;
if(tr[ft].anc)
{
rotate(spc);
return ;
}
if(whc(spc)^whc(ft))
rotate(spc);
else
rotate(ft);
rotate(spc);
}
return ;
}
void access(int spc)
{
int lst=;
while(spc)
{
splay(spc);
tr[rrr].anc=;
tr[lst].anc=;
rrr=lst;
pushup(spc);
lst=spc;
spc=tr[spc].fa;
}
return ;
}
void Mtr(int spc)
{
access(spc);
splay(spc);
trr(spc);
return ;
}
void Link(int spc,int y)
{
access(spc);
splay(spc);
tr[spc].fa=y;
return ;
}
void Cut(int x,int y)
{
Mtr(x);
access(y);
splay(x);
tr[x].rs=;
tr[y].anc=;
tr[y].fa=;
return ;
}
void split(int x,int y)
{
Mtr(x);
access(y);
splay(y);
}
int dest(int i)
{
return (i+nx[i]>n)?(n+):(i+nx[i]);
}
int main()
{
scanf("%d",&n);
for(int i=;i<=n+;i++)
tr[i].anc=;
for(int i=;i<=n;i++)
{
scanf("%d",&nx[i]);
Link(i,dest(i));
}
scanf("%d",&m);
while(m--)
{
int i,j,k;
scanf("%d",&i);
if(i==)
{
scanf("%d",&j);
j++;
split(j,n+);
printf("%d\n",tr[n+].wgt-);
}else{
scanf("%d%d",&j,&k);
j++;
Cut(j,dest(j));
nx[j]=k;
Link(j,dest(j));
}
}
return ;
}

最新文章

  1. Stimulsoft入门视频
  2. Runtime详解
  3. 面向服务架构(SOA)和企业服务总线(ESB)
  4. 知名杀毒软件Mcafee(麦咖啡)个人版 资源汇总兼科普(来自卡饭)
  5. 放肆的使用UIBezierPath和CAShapeLayer画各种图形
  6. 将VLC库封装为duilib的万能视频播放控件
  7. codevs 1066 引水入城
  8. windows服务程序
  9. iOS 之 编外知识点
  10. Android布局优化之层级优化
  11. Oracle定时任务小案例
  12. JAVA 继承基本类、抽象类、接口
  13. MySQL远程链接
  14. Python Django 2.1登录功能_1
  15. hadoop集群完全分布式搭建
  16. face_recognition
  17. ansbile Tags &amp;&amp; Block
  18. Vue-cli 搭建web服务介绍
  19. ASP.NET Web Api 2 接口API文档美化之Swagger
  20. 如何简单地理解Python中的if __name__ == &#39;__main__&#39;(https://blog.csdn.net/yjk13703623757/article/details/77918633)

热门文章

  1. Centos7 zabbix3.4.6的安装部署 (一)
  2. string类自定义字符串替换函数replace
  3. 简单的字符串压缩--C代码
  4. 原生ajax实现方式
  5. javaScript学习之正则表达式初探
  6. JAVA文件写入FileWriter
  7. pip版本及升级 pip安装指定模板
  8. Django_模板HTML
  9. WPF 支持的多线程 UI 并不是线程安全的
  10. [Python] Finding the most common elements in an iterable