[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
其他
> 详细
总结-分治
时间:
2015-04-05 09:07:50
阅读:
224
评论:
0
收藏:
0
[点我收藏+]
分治
分治法是一种效率很高的算法, 往往带有一个log级的复杂度.
1. CDQ分治
CDQ分治可以应用到带有修改操作的题目中, 对操作进行分治, 通过考虑前一半操作对后一半操作的影响达到分治的目的.
应用的条件比较苛刻
BZOJ-1492-货币兑换cash-NOI2007-CDQ分治
优化dp
BZOJ-2716-天使玩偶angel-CDQ分治
能这样做还得益于曼哈顿距离的特殊性
BZOJ-2001-city城市建设-HNOI2010-CDQ分治
因为最小生成树Kruskal算法是基于边的算法, 所以可以对边进行分治
2. 二分答案
路由器安置(Routing)
二分答案, 然后用到二分查找. 比较巧妙地是二分半径而不是直径, 这样可以避免出现小数.
BZOJ-3110-K大数查询-ZJOI2013-整体二分
整体二分的做法是比较BT的, 因为答案有上下界, 而且答案一定是前面的操作造成的, 所以直接对答案进行二分. 用到了线段树维护(也可以用树状数组). 思考: CDQ能做吗?
BZOJ-2440-完全平方数-中山市选2011-容斥原理-莫比乌斯函数-二分查找
二分答案用容斥原理判断.
3. 三分法
BZOJ-1857-传送带-SCOI2010
两次三分. 因为是两个单峰函数.
总结: 分治的思想很重要, 考场上如果能想到正确解法的话只要思路清晰, 代码难度适中吧.
总结-分治
原文:http://blog.csdn.net/qq_21110267/article/details/44876103
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!