2038: [2009国家集训队]小Z的袜子(hose)

Time Limit: 20 Sec  Memory Limit: 259 MB
Submit: 15784  Solved: 7164
[Submit][Status][Discuss]

Description

作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中找出一双来穿。终于有一天,小Z再也无法忍受这恼人的找袜子过程,于是他决定听天由命……
具体来说,小Z把这N只袜子从1到N编号,然后从编号L到R(L 尽管小Z并不在意两只袜子是不是完整的一双,甚至不在意两只袜子是否一左一右,他却很在意袜子的颜色,毕竟穿两只不同色的袜子会很尴尬。
你的任务便是告诉小Z,他有多大的概率抽到两只颜色相同的袜子。当然,小Z希望这个概率尽量高,所以他可能会询问多个(L,R)以方便自己选择。

Input

输入文件第一行包含两个正整数N和M。N为袜子的数量,M为小Z所提的询问的数量。接下来一行包含N个正整数Ci,其中Ci表示第i只袜子的颜色,相同的颜色用相同的数字表示。再接下来M行,每行两个正整数L,R表示一个询问。

Output

包含M行,对于每个询问在一行中输出分数A/B表示从该询问的区间[L,R]中随机抽出两只袜子颜色相同的概率。若该概率为0则输出0/1,否则输出的A/B必须为最简分数。(详见样例)

Sample Input

6 4
1 2 3 3 3 2
2 6
1 3
3 5
1 6

Sample Output

2/5
0/1
1/1
4/15
【样例解释】
询问1:共C(5,2)=10种可能,其中抽出两个2有1种可能,抽出两个3有3种可能,概率为(1+3)/10=4/10=2/5。
询问2:共C(3,2)=3种可能,无法抽到颜色相同的袜子,概率为0/3=0/1。
询问3:共C(3,2)=3种可能,均为抽出两个3,概率为3/3=1/1。
注:上述C(a, b)表示组合数,组合数C(a, b)等价于在a个不同的物品中选取b个的选取方案数。
【数据规模和约定】
30%的数据中 N,M ≤ 5000;
60%的数据中 N,M ≤ 25000;
100%的数据中 N,M ≤ 50000,1 ≤ L < R ≤ N,Ci ≤ N。

HINT

 

Source

版权所有者:莫涛

  莫队算法的入门题目。

  莫队算法就是对于类似f(i,j)能在O(1)的时间内推出来f(i-1,j),f(i,j+1),f(i+1,j),f(i,j-1)的话,对于数次离线的区间查询,对查询区间按照

L所在的块为第一关键字,R为第二关键字排序然后处理询问的话,复杂度是O(N*sqrt(N)),具体的证明不会,但是仔细想想也可以大概

模拟出来。他只是利用分块排序,实际处理询问时没有涉及到分块。知道他的简单原理之后就可以做一些模板题目了。

  这个题目对于[L,R],ans= SUM{C(2,cnt[i])}/C(2,R-L+1) ,cnt[i]表示区间内出现的所有不同的颜色的个数,化简之后的式子变成了,

( SUM{cnt[i]*cnt[i]}-(R-L+1) ) / (R-L+1)*(R-L) ,注意到只有分子的一部分在转移的时候变化一下就好了。

  

 #include<bits/stdc++.h>
using namespace std;
#define LL long long
#define eps 1e-6
LL gcd(LL a,LL b){
return b==?a:gcd(b,a%b);
}
LL ans[][],cnt[];
int col[],N,M,B;
struct Query{
int L,R,id;
bool operator<(const Query& C)const{
if(L/B!=C.L/B) return L/B<C.L/B;
return R<C.R;
}
}q[];
int main(){
scanf("%d%d",&N,&M);
B=sqrt(N);
for(int i=;i<=N;++i)scanf("%d",col+i);
for(int i=;i<=M;++i)scanf("%d%d",&q[i].L,&q[i].R),q[i].id=i;
sort(q+,q++M);
LL l=,r=,res=;
for(int i=;i<=M;++i){
while(r<q[i].R){
res+=((cnt[col[r+]]+)*(cnt[col[r+]]+)-cnt[col[r+]]*cnt[col[r+]]);
cnt[col[r+]]++;
r++;
}
while(r>q[i].R){
res+=((cnt[col[r]]-)*(cnt[col[r]]-)-(cnt[col[r]])*(cnt[col[r]]));
cnt[col[r]]--;
r--;
}
while(l<q[i].L){
res+=((cnt[col[l]]-)*(cnt[col[l]]-)-(cnt[col[l]])*(cnt[col[l]]));
cnt[col[l]]--;
l++;
}
while(l>q[i].L){
res+=((cnt[col[l-]]+)*(cnt[col[l-]]+)-(cnt[col[l-]])*(cnt[col[l-]]));
cnt[col[l-]]++;
l--;
}
ans[q[i].id][]=res-q[i].R+q[i].L-;
ans[q[i].id][]=(LL)(q[i].R-q[i].L+)*(q[i].R-q[i].L);
}
for(int i=;i<=M;++i){
if(ans[i][]==){
ans[i][]=;
continue;
}
LL g=gcd(ans[i][],ans[i][]);
ans[i][]/=g;
ans[i][]/=g;
}
for(int i=;i<=M;++i) printf("%lld/%lld\n",ans[i][],ans[i][]);
return ;
}

bzoj-2038-莫队的更多相关文章

  1. bzoj 2038 莫队入门

    http://www.lydsy.com/JudgeOnline/problem.php?id=2038 题意:多次询问区间内取出两个相同颜色的种类数 思路:由于不是在线更新,那么可以进行离线查询,而 ...

  2. bzoj 2038 莫队算法

    莫队算法,具体的可以看10年莫涛的论文. 大题思路就是假设对于区间l,r我们有了一个答案,那么对于区间l,r+1,我们 可以暴力的转移一个答案,那么对于区间l1,r1和区间l2,r2,需要暴力处理 的 ...

  3. BZOJ 3339 & 莫队+"所谓的暴力"

    题意: 给一段数字序列,求一段区间内未出现的最小自然数. SOL: 框架显然用莫队.因为它兹瓷离线. 然而在统计上我打了线段树...用&维护的结点...400w的线段树...然后二分查找... ...

  4. bzoj 3289 莫队 逆序对

    莫队维护逆序对,区间左右增减要分类讨论. 记得离散化. /************************************************************** Problem: ...

  5. bzoj 3809 莫队

    收获: 1.分块时顺便记录每个位置所属的块,然后一次排序就OK了. 2.要权衡在“区间移动”与“查询结果”之间的时间,莫队算法一般区间移动频率远大于查询结果,所以我们选择的辅助数据结构时就要注意了,我 ...

  6. bzoj 3339 莫队

    题意: 求任意一个区间的SG函数. 想到线段树,但是线段树合并很麻烦. 线段树——分块. 分块的一个应用就是莫队算法. 怎么暴力递推呢? 从一个区间到另一个区间,Ans 取决于 Ans 和 加入和删除 ...

  7. BZOJ 3236 莫队+树状数组

    思路: 莫队+树状数组 (据说此题卡常数) yzy写了一天(偷笑) 复杂度有点儿爆炸 O(msqrt(n)logn) //By SiriusRen #include <cmath> #in ...

  8. HYSBZ 2038 莫队算法

    小Z的袜子(hose) Time Limit:20000MS     Memory Limit:265216KB     64bit IO Format:%lld & %llu Submit  ...

  9. BZOJ 2308 莫队入门经典

    题目链接  https://www.lydsy.com/JudgeOnline/problem.php?id=2038 参考博客 https://www.cnblogs.com/Paul-Guderi ...

  10. BZOJ 3339 && BZOJ 3585 莫队+权值分块

    显然若一个数大于n就不可能是答案. #include <iostream> #include <cstring> #include <cstdio> #includ ...

随机推荐

  1. HDU 3333 Turing Tree(树状数组/主席树)

    题意 给定一个长度为 \(n​\) 的序列,\(m​\) 个查询,每次查询区间 \([L,R]​\) 范围内不同元素的和. \(1\leq T \leq 10\) \(1 \leq n\leq 300 ...

  2. Docker7之Docker overview

    Docker is an open platform for developing, shipping, and running applications. Docker enables you to ...

  3. 最小 base64 图片

    http://www.webhek.com/post/base64-encode-of-1x1px-transparent-gif.html Base64 Encode 1x1px透明GIF图片 Ba ...

  4. 移动端开发:使用jQuery Mobile还是Zepto

    原:http://blog.csdn.net/liubinwyzbt/article/details/51446771 jQuery Mobile和Zepto是移动端的js库.jQuery Mobil ...

  5. JMeter中关于动态切换不同CSV文件解决方案

    最近写case,需要当前播放节目的数据作为输入数据,所以每个时刻所用的数据只能是当前时刻附件的数据,尝试用CSV Data Set Config动态加载不同的文件,没有成功,好像CSV Data Se ...

  6. Excel 导出通用类

    public class ExportToExcelHelper { public static void ExportExcel(DataTable dt) { try { //创建一个工作簿 IW ...

  7. java多线程同步机制

    一.关键字: thread(线程).thread-safe(线程安全).intercurrent(并发的) synchronized(同步的).asynchronized(异步的). volatile ...

  8. 【BZOJ】3140: [Hnoi2013]消毒

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3140 猜一发(显然)有结论:每次一定选择一个平面,即每次操作对答案的贡献都为$1$ 首先可 ...

  9. testin 测试用例管理平台

    应用信息:应用图标,应用名称,版本号,应用包名,系统平台[Android,ios,Web/H5,小程序,快应用]项目成员:成员帐号[邮箱],成员姓名,成员角色,成员职位,状态[激活,未激活],操作[移 ...

  10. java类加载器和双亲委派模型

    一. 类加载器 ClassLoader即常说的类加载器,其功能是用于从Class文件加载所需的类,主要场景用于热部署.代码热替换等场景. 系统提供3种的类加载器:Bootstrap ClassLoad ...