bzoj2002
这道题学习了一种简洁的解决一些数据结构题的方法——分块法
这道题方法很多,但分块写起来只有1kb左右,非常的简洁(但不是非常的高效)
首先很容易思考到一种暴力的做法,从后往前推,很容易搞出每个点会弹几次弹出,
这样询问是O(1),但修改一个弹力系数必须把之前会弹到这个点的步数都要修改,因此我们使用分块优化
我们把数列划分成一个个大小为[sqrt(n)]的块(最后一块大小具体计算),
令f[i]表示弹出i所在块所用的次数,p[i]表示最终弹出i所在块后弹到下一块的位置
首先f[i],p[i]都是可以预处理出来的
然后查询,显然我们只要最多遍历块的个数 是O(sqrt(n))
修改,我们只要修改这个点之前,且属于同一个块的点即可,最坏也是O(sqrt(n))
这样总的复杂度为O(m*sqrt(n))
bzoj2002的更多相关文章
- 【bzoj2002】[Hnoi2010]Bounce 弹飞绵羊 分块
		[bzoj2002][Hnoi2010]Bounce 弹飞绵羊 2014年7月30日8101 Description 某天,Lostmonkey发明了一种超级弹力装置,为了在他的绵羊朋友面前显摆,他邀 ... 
- 【BZOJ2002】弹飞绵羊(Link-Cut Tree)
		[BZOJ2002]弹飞绵羊(Link-Cut Tree) 题面 题目描述 某天,Lostmonkey发明了一种超级弹力装置,为了在他的绵羊朋友面前显摆,他邀请小绵羊一起玩个游戏.游戏一开始,Lost ... 
- 【BZOJ2002】 [Hnoi2010]Bounce 弹飞绵羊
		BZOJ2002 [Hnoi2010]Bounce 弹飞绵羊 Solution 很早以前写的一道分块题,最近在搞LCT,又做了一遍. 1.LCT做法 看到这种动态修改,想下LCT怎么维护. 修改操作就 ... 
- 【bzoj2002】 Hnoi2010—Bounce 弹飞绵羊
		http://www.lydsy.com/JudgeOnline/problem.php?id=2002 (题目链接) 题意 数轴上${n}$个点,每个点有一个权值${a_i}$,如果到达这个点,接下 ... 
- 【lct】bzoj2002 [Hnoi2010]Bounce 弹飞绵羊
		lct板子,此题主要有cut操作和link操作. #include<cstdio> #include<iostream> #include<cstring> #in ... 
- BZOJ2002 Hnoi2010 Bounce 弹飞绵羊 【LCT】【分块】
		BZOJ2002 Hnoi2010 Bounce 弹飞绵羊 Description 某天,Lostmonkey发明了一种超级弹力装置,为了在他的绵羊朋友面前显摆,他邀请小绵羊一起玩个游戏.游戏一开始, ... 
- BZOJ2002弹飞绵羊
		动态树LCT模板题 #include<cstdio> #include<cctype> #include<algorithm> using namespace st ... 
- 【BZOJ2002】弹飞绵羊(LCT)
		题意:给定一棵树,要求维护以下操作: 1.删除连接(x,y)的边 2.将(x,y)之间连边 3.询问某点子树大小 对于100%的数据n<=200000,m<=100000 思路:第一道有加 ... 
- [bzoj2002][Hnoi2010]Bounce弹飞绵羊_LCT
		Bounce弹飞绵羊 bzoj-2002 Hnoi-2010 题目大意:n个格子,每一个格子有一个弹簧,第i个格子会将经过的绵羊往后弹k[i]个,达到i+k[i].如果i+k[i]不存在,就表示这只绵 ... 
- [BZOJ2002][洛谷P3203][Hnoi2010]Bounce 弹飞绵羊(LCT维护链长)
		luogu传送门 2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 16082 Solved: ... 
随机推荐
- 用bootstrap的tab插件做一个图层切换效果(感觉会误导淫们,大家当乐子看吧)
			小伙伴们啊,我JS真的是个渣渣,所以总想要偷懒,于是为了实现效果就把tab插件给改了(各位大神轻拍啊,我是小白,很纯洁滴,小心脏也很脆弱)…… 最近做的项目为了考虑以后的移动设备兼容性,所以用了Boo ... 
- (转) Spring读书笔记-----部署我的第一个Spring项目
			一.Spring介绍 Spring是一个轻量级的Java EE容器,它也是一种从实际需求出发,着眼于轻便,灵活,易于开发,易测试和易部署的轻量级开发框架.Spring它完成了大量开发中的通用步骤,留给 ... 
- Canvas保存图片保存到本地
			使用Canvas绘图,将图片保存到本地方法 一.使用HTML5 a标签的download属性,将图片保存到本地,不需要链接服务器 关于download属性:HTML5 <a>标签downl ... 
- 学习java随笔第十篇:java线程
			线程生命周期 线程的生命周期:新建状态.准备状态.运行状态.等待/阻塞状态.死亡状态 示意图: 定义.创建及运行线程 线程: package threadrun; //定义一个实现Runnable接口 ... 
- 在Android上模拟登录广工正方教务系统查询成绩
			这是在博客园里开博以来写的第一篇博客. 因为之前看过很多人都有发过关于模拟登录正方软件获取数据的文章,自己觉得挺好玩的便也去动手一做,开始还以为挺难的,但实际做起来还蛮简单的,当然其中还有些小插曲. ... 
- SQLSERVER2008 显示列信息,包含扩展属性
			select b.name as table_name,a.name as column_name,t.name type_name ,a.max_length ,a.precision ... 
- windows下安装wamp和wordpress
			安装wamp WAMP是一个windows上的php开发集成环境,一键安装php,apache和mysql,非常方便. 双击wampserver2.2exxxxxxxxxx.exe文件进行安装,安装过 ... 
- BearSkill实用方法之UITextField限制输入的字符数量
			原文:http://blog.csdn.net/xiongbaoxr/article/details/51525061 
- 通过JS判断联网类型和连接状态
			通过JS判断联网类型和连接状态 中国的移动网络环境复杂,为了给用户带去更好访问体验,开发者希望能了解用户当前的联网方式,然后给用户一个符合当前网络环境的请求结果. W3C的规范中给出了一个方法来获得现 ... 
- 【转】ASP.NET MVC教程
			转自:http://www.cnblogs.com/QLeelulu/category/123326.html ASP.NET MVC的最佳实践与性能优化的文章 摘要: 就一些文章链接,就不多废话了. ... 
