2002: [Hnoi2010]Bounce 弹飞绵羊

时间限制: 10 Sec  内存限制: 259 MB

题目描述

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

输入

第一行包含一个整数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

输出

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

样例输入

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

样例输出

2
3
 
算法:分块
思路:将n个数分成若干块,每一块是单独的一部分,互不干扰,每一块的任意节点都是直接跳到下一块的位置,这个从代码里理解,查询的时间复杂度最多也是O(sqrt(n)),这样大大减少了时间,每修改一个值的话,便更新那个值所在的那个块区域,不影响其他区域。
 
#include <iostream>
#include <cstdio>
#include <cmath> using namespace std; int a[]; //存取当前数组下一步走的距离
int v[]; //存取下一步的位置
int step[]; //存取当前的步数
int left1[]; //存取左端点的位置
int right1[]; //存取右端点的位置
int belong[]; //存取当前位置属于哪一块 int main() {
int n;
scanf("%d", &n);
int block = sqrt(n);
int num = n / block;
if(n % block) {
num++;
}
for(int i = ; i <= num; i++) {
left1[i] = (i - ) * block + ;
right1[i] = i * block;
}
for(int i = ; i <= n; i++) {
scanf("%d", &a[i]);
belong[i] = (i - ) / block + ;
}
//前面基本上都是模板,从这里开始变形
for(int i = n; i >= ; i--) {
v[i] = a[i] + i; //获取下一个位置
step[i] = ; //步数初始化
if(v[i] <= n && belong[i] == belong[v[i]]) { //判断下一步的位置和当前位置是否再同一块里,如果在的话便更新状态
  //注意,下面这两部分千万不能写反了,不然就会出问题,当初的我...流泪...
  //因为你换一下位置的话就是更新为下下步的位置了
step[i] = step[v[i]] + ;   //更新为下一步的步数
v[i] = v[v[i]]; //更新为下一步的位置
}
}
int m;
scanf("%d", &m);
while(m--) {
int q, x, y;
scanf("%d", &q);
if(q == ) {
scanf("%d", &x);
x++; //千万记住这里要自增一下,因为题目里说明了是0 ~ n-1
int ans = ;
while(x <= n) { //一块一块找过去,获取结果
ans += step[x];
x = v[x];
}
printf("%d\n", ans);
} else {
scanf("%d %d", &x, &y);
x++; //同上,自增
a[x] = y;
//只需要更新改变值的那一块
for(int i = right1[belong[x]]; i >= left1[belong[x]]; i--) {
v[i] = a[i] + i;
step[i] = ;
if(v[i] <= n && belong[i] == belong[v[i]]) {
step[i] = step[v[i]] + ;
v[i] = v[v[i]];
}
}
}
} return ;
}
 

2002: [Hnoi2010]Bounce 弹飞绵羊(分块)的更多相关文章

  1. BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊 分块

    2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOn ...

  2. BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊 【分块】

    任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=2002 2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 ...

  3. bzoj 2002 : [Hnoi2010]Bounce 弹飞绵羊 (LCT)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2002 题面: 2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: ...

  4. 【BZOJ】2002: [Hnoi2010]Bounce 弹飞绵羊

    2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 14802  Solved: 7507[Subm ...

  5. BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊

    2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 9071  Solved: 4652[Submi ...

  6. BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊 LCT

    2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOn ...

  7. bzoj 2002: [Hnoi2010]Bounce 弹飞绵羊 動態樹

    2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 4055  Solved: 2172[Submi ...

  8. BZOJ 2002: [Hnoi2010]Bounce 弹飞绵羊 (动态树LCT)

    2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 2843  Solved: 1519[Submi ...

  9. 2002: [Hnoi2010]Bounce 弹飞绵羊

    2002: [Hnoi2010]Bounce 弹飞绵羊 https://www.lydsy.com/JudgeOnline/problem.php?id=2002 分析: 绵羊在弹飞的路径中相当于一棵 ...

随机推荐

  1. AC自动机练习题1:地图匹配

    AC自动机板子,学习之前要是忘记了就看一下 1465: [AC自动机]地图匹配 poj1204 时间限制: 1 Sec  内存限制: 256 MB提交: 78  解决: 46[提交] [状态] [讨论 ...

  2. JS中this的4种绑定规则

    this ES6中的箭头函数采用的是词法作用域. 为什么要使用this:使API设计得更简洁且易于复用. this即不指向自身,也不指向函数的词法作用域. this的指向只取决于函数的调用方式 thi ...

  3. Windows Runtime (RT)

    学了sl for wp 开发了1年都没入门,只能说自己的学习欲望太低了. 今天偶然才发现wrt 跟 .net 是2个东西... orz. 得抛弃 sl ,wrt才是未来的主流吧... 这篇文章不错 h ...

  4. 通过PlayBook部署Zabbix

    编写Linux初始化剧本 初始化剧本环节,主要用户实现关闭Selinux关闭防火墙,一起配置一下阿里云的YUM源地址,和安装EPEL源,为后期的zabbix安装做好铺垫工作. 1.在安装Zabbix之 ...

  5. 第三章 联接查询 T-SQL语言基础

    联接查询 sql server 2008支持四种表运算符----JOIN,APPLY,PIVOT,UNPIVOT. JOIN表运算符是ANSI标准,而APPLY,PIVOT,UNPIVOT是T-SQL ...

  6. 【转载】Linux GCC常用命令

    作者:ggjucheng 出处:https://www.cnblogs.com/ggjucheng/archive/2011/12/14/2287738.html 1简介 2简单编译 2.1预处理 2 ...

  7. 为什么angular library的build不能将assets静态资源打包进去(转)

    Versions Angular CLI: 6.0.7 Node: 9.3.0 OS: darwin x64 Angular: 6.0.3 ... animations, common, compil ...

  8. Delphi 程序调试

  9. 第十篇.4、python并发编程之多线程

    一 threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性,因而不再详细介绍 官网链接:https://docs.python ...

  10. Linux系统下C语言获取Time

    获取时间的函数有很多,具体包括如下: time()/gettimeofday()等等,下面是获取具体到usecond的时间程序: #include <iostream> #include ...