bzoj 2038 莫队算法
莫队算法,具体的可以看10年莫涛的论文。
大题思路就是假设对于区间l,r我们有了一个答案,那么对于区间l,r+1,我们
可以暴力的转移一个答案,那么对于区间l1,r1和区间l2,r2,需要暴力处理
的部分就是|r1-r2|+|l1-l2|如果将l看成x,r看成r,得到的暴力部分就是manhattan距离
那么我们将所有的询问,构成一张二维图,可以从一个点转移到另一个点,且总manhattan距离
尽可能的小,所以可以建立一颗manhattan mst,这样的话就可以得到最优的转移,但是实际来说
搞定一个manhattan mst需要的时间不小,我们可以不要最优解,将询问按l分块,只需要做到在每个
块中尽可能的优就行了,所以每个块中可以根据r排序,然后搞就行了
经莫队证明,这个算法的复杂度上界大概是o(n^1.5)
/**************************************************************
Problem:
User: BLADEVIL
Language: Pascal
Result: Accepted
Time: ms
Memory: kb
****************************************************************/
//By BLADEVIL
type
rec =record
l, r, w, s :longint;
end;
var
n, m :longint;
c, size :array[..] of int64;
len :longint;
a :array[..] of rec;
now :longint;
col, ans :array[..] of int64;
all, num :int64;
procedure swap(var a,b:longint);
var
c :longint;
begin
c:=a; a:=b; b:=c;
end;
procedure swap_rec(var a,b:rec);
var
c :rec;
begin
c:=a; a:=b; b:=c;
end;
function gcd(a,b:int64):int64;
begin
if a<b then exit(gcd(b,a)) else
if b= then exit(a) else exit(gcd(b,a mod b));
end;
procedure qs(low,high:longint);
var
i, j, xx, yy :longint;
begin
i:=low; j:=high; xx:=a[(i+j) div ].w;
yy:=a[(i+j) div ].r;
while i<j do
begin
while (a[i].w<xx) or (a[i].w=xx) and (a[i].r<yy) do inc(i);
while (a[j].w>xx) or (a[j].w=xx) and (a[j].r>yy) do dec(j);
if i<=j then
begin
swap_rec(a[i],a[j]);
inc(i); dec(j);
end;
end;
if i<high then qs(i,high);
if j>low then qs(low,j);
end;
procedure init;
var
i :longint;
begin
read(n,m);
for i:= to n do read(c[i]);
len:=trunc(sqrt(m));
for i:= to m do
begin
read(a[i].l,a[i].r);
if a[i].l>a[i].r then swap(a[i].l,a[i].r);
size[i]:=a[i].r-a[i].l+;
a[i].w:=a[i].l div len+;
a[i].s:=i;
end;
qs(,m);
end;
procedure main;
var
i, j :longint;
begin
i:=;
while i<=m do
begin
now:=a[i].w;
fillchar(col,sizeof(col),);
for j:=a[i].l to a[i].r do
begin
ans[a[i].s]:=ans[a[i].s]+*(col[c[j]]);
col[c[j]]:=col[c[j]]+;
end;
inc(i);
while a[i].w<=now do
begin
ans[a[i].s]:=ans[a[i-].s];
for j:=a[i-].r+ to a[i].r do
begin
ans[a[i].s]:=ans[a[i].s]+*(col[c[j]]);
col[c[j]]:=col[c[j]]+;
end;
if a[i-].l<a[i].l then
begin
for j:=a[i-].l to a[i].l- do
begin
col[c[j]]:=col[c[j]]-;
ans[a[i].s]:=ans[a[i].s]-*col[c[j]];
end;
end else
for j:=a[i].l to a[i-].l- do
begin
ans[a[i].s]:=ans[a[i].s]+*(col[c[j]]);
col[c[j]]:=col[c[j]]+;
end;
inc(i);
if i>m then break;
end;
end;
for i:= to m do
begin
if size[i]= then all:= else all:=size[i]*(size[i]-);
num:=gcd(ans[i],all);
writeln(ans[i] div num,'/',all div num);
end;
end;
begin
init;
main;
end.
bzoj 2038 莫队算法的更多相关文章
- bzoj 2038 莫队入门
http://www.lydsy.com/JudgeOnline/problem.php?id=2038 题意:多次询问区间内取出两个相同颜色的种类数 思路:由于不是在线更新,那么可以进行离线查询,而 ...
- HYSBZ 2038 莫队算法
小Z的袜子(hose) Time Limit:20000MS Memory Limit:265216KB 64bit IO Format:%lld & %llu Submit ...
- BZOJ 2038: [2009国家集训队]小Z的袜子(hose) [莫队算法]【学习笔记】
2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 7687 Solved: 3516[Subm ...
- 【BZOJ】2038: [2009国家集训队]小Z的袜子(hose)(组合计数+概率+莫队算法+分块)
http://www.lydsy.com/JudgeOnline/problem.php?id=2038 学了下莫队,挺神的orzzzz 首先推公式的话很简单吧... 看的题解是从http://for ...
- bzoj 2038 [2009国家集训队]小Z的袜子(hose)(莫队算法)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2038 [题意] 给定一个有颜色的序列,回答若干个询问:区间内任选两个颜色相同的概率. ...
- BZOJ 2038: [2009国家集训队]小Z的袜子(hose)【莫队算法裸题&&学习笔记】
2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 9894 Solved: 4561[Subm ...
- bzoj 2038 A-小Z的袜子[hose] - 莫队算法
作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿.终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命…… 具体来说,小Z把这N只袜子从1到N编号,然后从 ...
- BZOJ 2038 小Z的袜子(hose) 莫队算法模板题
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=2038 题目大意: 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中 ...
- BZOJ 2038: [2009国家集训队]小Z的袜子(hose) 【莫队算法模版】
任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=2038 题意概括: 有 N 只袜子(分别编号为1~N),有 M 次查询 (L, R)里面随机 ...
随机推荐
- PeopleSoft Object Types Definitions
PeopleSoft stores object definitions types such as Record, Field and SQL definitions as numbers in ...
- 未能正确加载“Microsoft.VisualStudio.Implementation.EditorPackage”包
未能正确加载“Microsoft.VisualStudio.Implementation.EditorPackage”包 未处理ImportCardinalityMismatchException 未 ...
- [leetcode]_Remove Nth Node From End of List
题目:移除linked-list从尾到头的第N个元素 自我思路:因为题目给出的N是从链表尾开始计算的,单链表不存在从子指向父亲的反向指针,因此我先计算链表的整个长度len,然后用len - N来表示正 ...
- nginx+php与apache+php性能对比
测试工具http_load相同的动态页面测试,相同的硬件资源,相同并发,相同请求数量的前提下,nginx+php比apache+php的性能要 差,而且如果请求的压力大于硬件资源的承受能力,nginx ...
- 【转载!】关于C#的RawSocket编程的问题
Q:你好! 看过了你在csdn上发表的<用C#下的Raw Socket编程实现网络封包监视>,觉得很感兴趣,而且对我的帮助很大.不过在调试的过程中遇到一些问题,特此向你请教一下.谢谢! 首 ...
- python网络画图——networkX
networkX tutorial 绘制基本网络图 用matplotlib绘制网络图 基本流程: 1. 导入networkx,matplotlib包 2. 建立网络 3. 绘制网络 nx.draw() ...
- linux回环网卡驱动设计
回环网卡驱动 1.回环网卡和普通网卡的区别是他是虚拟的不是实际的物理网卡,它相当于把普通网卡的发送端和接收端短接在一起. 2.在内核源代码里的回环网卡程序(drivers/net/loopback.c ...
- python基础学习笔记第四天 list 元祖 字典
一 LIST方法 列表操作包含以下函数:1.cmp(list1, list2):比较两个列表的元素 2.len(list):列表元素个数 3.max(list):返回列表元素最大值 4.min(lis ...
- [terry笔记]Oracle数据泵-schema导入导出
数据泵是10g推出的功能,个人倒数据比较喜欢用数据泵. 其导入的时候利用remap参数很方便转换表空间以及schema,并且可以忽略服务端与客户端字符集问题(exp/imp需要排查字符集). 数据泵也 ...
- Python核心编程--学习笔记--1--Python简介
本章介绍了Python的背景知识,包括什么是Python.Python的起源以及Python的一些关键特性. 1 什么是Python Python是一门优雅而健壮的编程语言,它继承了传统编译语言的强大 ...