[ BZOJ 2038 ] Hose
\(\\\)
Description
给出一个数列,多次询问,每次给出一个区间 \([l_i,r_i]\) ,问在区间中随意选两个位置不同的数,是同一个数的概率有多大。
- \(n,m\le 5\times 10^4\)
\(\\\)
Solution
莫队模板。
才发现自己还没有正经学过莫队
设 \(cnt[i]\) 表示 \(i\) 在 \([l,r]\) 中出现的个数,\(S\) 为这个区间的数集,一个区间的答案可以表示成:
\]
分母好说,考虑如何求分子,不妨展开一下。
\]
于是有一个机智的做法:我们设 \(ans\) 表示括号里面的东西。
每次区间移动时,假如 \(cnt[x]\to cnt[x]'\) ,那么对 \(ans\) 的更新有:
\]
就可以 \(O(1)\) 移动回答区间的左端点或右端点了。
关于询问的排序:左端点在同一个块内的按照右端点排序,不在同一个块内的按照左端点所在块排序。
这样每个块右端点至多移动 \(O(N)\),左端点至多移动 \(O(q\sqrt N)\) ,其中 \(q\) 是左端点在这个块内的询问个数。
总复杂度 \(O(N\sqrt N)\)
\(\\\)
Code
#include<cmath>
#include<cstdio>
#include<cctype>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 50010
#define R register
#define gc getchar
using namespace std;
typedef long long ll;
inline ll rd(){
ll x=0; char c=gc();
while(!isdigit(c)) c=gc();
while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=gc();}
return x;
}
ll ans,n,m,s[N],cnt[N],bl[N];
struct Q{ll l,r,id,ans1,ans2;}q[N];
inline bool cmp(Q x,Q y){
return bl[x.l]==bl[y.l]?x.r<y.r:bl[x.l]<bl[y.l];
}
inline bool cmp1(Q x,Q y){return x.id<y.id;}
inline ll C(ll x){return (x*(x-1)>>1);}
ll gcd(ll x,ll y){return y?gcd(y,x%y):x;}
inline void move(ll &llst,ll &rlst,ll lnew,ll rnew){
while(llst<lnew){
int x=cnt[s[llst]];
ans=ans-x*x+(x-1)*(x-1)+1;
--cnt[s[llst]]; ++llst;
}
while(llst>lnew){
--llst;
int x=cnt[s[llst]];
ans=ans-x*x+(x+1)*(x+1)-1;
++cnt[s[llst]];
}
while(rlst<rnew){
++rlst;
int x=cnt[s[rlst]];
ans=ans-x*x+(x+1)*(x+1)-1;
++cnt[s[rlst]];
}
while(rlst>rnew){
int x=cnt[s[rlst]];
ans=ans-x*x+(x-1)*(x-1)+1;
--cnt[s[rlst]]; --rlst;
}
}
int main(){
ll n=rd(),m=rd();
ll t=sqrt(n);
for(R ll i=1,cntt=1;i<=n;++i){
if(i%t==0) ++cntt;
bl[i]=cntt;
}
for(R ll i=1;i<=n;++i) s[i]=rd();
for(R ll i=1;i<=m;++i){q[i].l=rd();q[i].r=rd();q[i].id=i;}
sort(q+1,q+1+m,cmp);
ll lnow=1,rnow=1;
++cnt[s[1]];
for(R ll i=1,g;i<=m;++i){
if(q[i].l==q[i].r){
q[i].ans1=0;
q[i].ans2=1;
continue;
}
move(lnow,rnow,q[i].l,q[i].r);
g=gcd(ans/2,C(q[i].r-q[i].l+1));
q[i].ans1=ans/g/2;
q[i].ans2=C(q[i].r-q[i].l+1)/g;
}
sort(q+1,q+1+m,cmp1);
for(R int i=1;i<=m;++i) printf("%lld/%lld\n",q[i].ans1,q[i].ans2);
return 0;
}
[ BZOJ 2038 ] Hose的更多相关文章
- 【莫队】bzoj 3781,bzoj 2038,bzoj 3289
好像又有一个星期没更博客了.. 最近疯狂考试...唯一有点收获的就是学会了莫队这种神奇的算法.. 听起来很难..其实是一个很简单的东西.. 就是在区间处理问题时对于一个待求区间[L',R']通过之前求 ...
- [BZOJ 2038]小Z的袜子
传送门:BZOJ 2038 题意很明确,是在给定的区间内任意选取两个数,求选到两个相同的数的概率. 所以我们得首先统计在给定的区间内,相同的数对有多少对,那么这里就使用到了莫队算法.如果对莫队算法还不 ...
- BZOJ 2038: [2009国家集训队]小Z的袜子
二次联通门 : BZOJ 2038: [2009国家集训队]小Z的袜子 /* BZOJ 2038: [2009国家集训队]小Z的袜子 莫队经典题 但是我并不认为此题适合入门.. Answer = ∑ ...
- 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)
2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 7676 Solved: 3509[Subm ...
- Bzoj 2038: [2009国家集训队]小Z的袜子(hose) 莫队,分块,暴力
2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 5763 Solved: 2660[Subm ...
- BZOJ 2038: [2009国家集训队]小Z的袜子(hose) ( 莫队 )
莫队..先按sqrt(n)分块, 然后按块的顺序对询问排序, 同块就按右端点排序. 然后就按排序后的顺序暴力求解即可. 时间复杂度O(n1.5) --------------------------- ...
- BZOJ 2038: [2009国家集训队]小Z的袜子(hose) 分块
分块大法好 2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MB Submit: 2938 Solved: 13 ...
- BZOJ 2038: [2009国家集训队]小Z的袜子(hose)【莫队算法裸题&&学习笔记】
2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec Memory Limit: 259 MBSubmit: 9894 Solved: 4561[Subm ...
随机推荐
- sql server 系统常用函数:聚合函数 数学函数 字符串函数 日期和时间函数和自定义函数
一.系统函数 1.聚合函数 聚合函数常用于GROUP BY子句,在SQL Server 2008提供的所有聚合函数中,除了COUNT函数以外,聚合函数都会忽略空值AVG.COUNT.COUNT_BIG ...
- S2SH的集成(Struts2,Spring,Hibernate)----青软S2SH(笔记)
- BootstrapValidator demo
source:http://bv.doc.javake.cn/api/ BootstrapValidator is the best jQuery plugin to validate form fi ...
- 20170111 ABAP技术小结(全半角转换)
DATA: it_po LIKE it_alv OCCURS 0 WITH HEADER LINE.************************************************** ...
- 3.5Linux设备驱动--块设备(一)之概念和框架☆☆
基本概念 块设备(blockdevice) --- 是一种具有一定结构的随机存取设备,对这种设备的读写是按块进行的,他使用缓冲区来存放暂时的数据,待条件成熟后,从缓存一次性写入设备或者从设备一次性 ...
- import-module in $profile
$PROFILE C:\Users\clu\Documents\PowerShell\Microsoft.PowerShell_profile.ps1 Import-Module 'C:\Users\ ...
- Persisting Data to the Device
Persisting Data to the Device Edit PagePage History Overview The Android framework offers several op ...
- ab压力测试-突破最大线程数
ab压力测试中,发现你一次最多只能启动1024个线程 默认情况下,一个线程的栈要预留1M的内存空间 而一个进程中可用的内存空间只有2G,所以理论上一个进程中最多可以开2048个线程 但是内存当然不可能 ...
- bzoj1878 [SDOI2009]HH的项链——树状数组
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1878 离线树状数组,巧妙的思路呢: 给每种项链记录一个最后出现的位置lst,根据项链最后出现 ...
- Git 仓库结构 (二)***
一.GIT工作流程 了解git,首先要弄清楚对象在被git管理过程中所处的4个阶段,分别是: 工作目录 index(又称为暂存区) 本地仓库 远程仓库. 从时间先后来讲,工作目录的内容是你当前看到的, ...