[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
其他
> 详细
bzoj3295(线段树套平衡树(treap))
时间:
2014-09-02 20:01:45
阅读:
374
评论:
0
收藏:
0
[点我收藏+]
3295: [Cqoi2011]动态逆序对
Time Limit:
10 Sec
Memory Limit:
128 MB
Submit:
861
Solved:
287
[
Submit
][
Status
]
Description
对于序列A,它的逆序对数定义为满足
i
<
j
,且A
i
>A
j
的数对(
i
,
j
)的个数。给1到
n
的一个排列,按照某种顺序依次删除
m
个元素,你的任务是在每次删除一个元素之前统计整个序列的逆序对数。
Input
输入第一行包含两个整数
n
和
m
,即初始元素的个数和删除的元素个数。以下
n
行每行包含一个1到
n
之间的正整数,即初始排列。以下
m
行每行一个正整数,依次为每次删除的元素。
Output
输出包含
m
行,依次为删除每个元素之前,逆序对的个数。
Sample Input
5 4
1
5
3
4
2
5
1
4
2
Sample Output
5
2
2
1
样例解释
(1,5,3,4,2)(1,3,4,2)(3,4,2)(3,2)(3)。
HINT
N<=100000 M<=50000
题意:RT
思路:线段树套平衡树碾压~第一次写,居然1Y了,6420MS,不知道是慢还是快
动态的删除元素,这个可以用线段树来完成,线段树里的每个节点维护一棵平衡树,当要删除一个元素时将包含该元素的所有线段树的节点都插入到节点所对应的平衡树
里面,然后预处理出每个元素的前面有多少个元素比它大和后面有多少个元素比它小,每次查询,只需要在包含的线段里查出比现在要删除的元素大的以及小的,这个可
以在各个节点所维护的平衡树里完成,然后细节看代码吧~~
bzoj3295(线段树套平衡树(treap))
原文:http://blog.csdn.net/cq_phqg/article/details/39009271
踩
(
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
版权所有
打开技术之扣,分享程序人生!