zoukankan
html css js c++ java
之前一道求逆序的线段树模板
struct
node
{
int
l,r;
node
*
pl,
*
pr;
int
count;
}
mem[
200
];
int
mem_pos;
int
anti, n, ans[
200
], num[
200
];
node
*
root;
node
*
new_node()
{
node
*
pt
=
&
mem[mem_pos
++
];
memset(pt,
0
,
sizeof
(node));
return
pt;
}
node
*
make_tree(
int
il,
int
ir,
bool
flag)
{
node
*
root
=
new_node();
root
->
l
=
il;
root
->
r
=
ir;
if
(flag)
{
root
->
count
=
ir
-
il
+
1
;
}
if
(il
!=
ir)
{
int
mid
=
(il
+
ir)
/
2
;
root
->
pl
=
make_tree(il, mid,flag);
root
->
pr
=
make_tree(mid
+
1
, ir,flag);
}
return
root;
}
int
find(node
*
root,
int
num)
{
root
->
count
--
;
if
(root
->
l
==
root
->
r)
{
return
root
->
l;
}
if
(root
->
pl
->
count
>
num)
{
//
left
return
find(root
->
pl, num);
}
else
{
//
right
return
find(root
->
pr, num
-
root
->
pl
->
count);
}
}
void
update(node
*
root,
int
num)
{
root
->
count
++
;
if
(root
->
l
==
num
&&
root
->
r
==
num)
{
return
;
}
if
(root
->
pl
->
r
>=
num)
{
//
left
anti
+=
root
->
pr
->
count;
update(root
->
pl, num);
}
else
{
//
right
update(root
->
pr, num);
}
}
void
cal_P()
{
int
i,j;
for
(i
=
1
;i
<=
n;i
++
)
{
anti
=
0
;
update(root, num[i]);
ans[ num[i] ]
=
anti;
}
}
void
cal_I()
{
int
i,j;
for
(i
=
1
;i
<=
n;i
++
)
{
ans[ find(root, num[i]) ]
=
i;
}
}
查看全文
相关阅读:
php iconv函数转换出错问题
linux 上配置swoole
Linux中查看某 个软件的安装路径
mysql 5.0存储过程学习总结
maven--私服的搭建(Nexus的使用)
Linux的chattr与lsattr命令详解
[转]Delphi 中 image 控件加载bmp、JPG、GIF、PNG等图片的办法
[转]Delphi 中动态链接库(dll)的建立和使用
Delphi PChar与String互转
[转]Delphi 快捷键 让你更像高手!!
原文地址:https://www.cnblogs.com/SQL/p/912730.html
最新文章
Ubuntu 安装VirtualBox 虚拟机
mysql 优化
JAVA中toString方法的作用
并发 ping
Java关键字final、static使用总结
继承 多态 重写 重载 接口
第一次冲刺-个人总结04
用户场景分析
第一次个人冲刺-个人总结03
第一次冲刺-个人总结02
热门文章
第一次冲刺-个人工作总结01
第十三周学习进度条
四则运算三
构建之法阅读笔记2
十二周学习进度条
构建之法阅读笔记01
wamp memcache 的安装与扩展(Windows 64)
控制DIV内容滚动的方法,实现不用拖滚动条就可以看到最新消息
HTTP 中 GET 与 POST 的区别
爱奇艺免费vip观看地址
Copyright © 2011-2022 走看看