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. 【ASP.Net】publish asp.net to local IIS

    做web项目难免要将项目部署, 要么部署在azure上,要么部署在本地, 使用IIS去host. 部署步骤很简单, 1. vs打开你的web项目, 项目名上面右键选择publish 2. 在弹出的pu ...

  2. Docker run 出现问题如何调试?

    docker run -ti 3f5dd697cc83 /bin/bash #进入image的目录 ls -l #列出所有目录 dotnet run WestWin.Ads.Crawler.WebAp ...

  3. tomcat启动出现Preparing launch delegate,一直卡在100%

    本地启动项目时,Tomcat一直停留在, Starting Tomcat V8.0 Server at localhost   Preparing launch delegate...    百度可得 ...

  4. H5手机移动端调起浏览器(qq浏览器,uc浏览器)自带分享功能实例

    H5手机移动端调起浏览器(qq浏览器,uc浏览器)自带分享功能实例 (转载:https://blog.csdn.net/weixin_38787928/article/details/86741227 ...

  5. codeforces gym 101164 K Cutting 字符串hash

    题意:给你两个字符串a,b,不区分大小写,将b分成三段,重新拼接,问是否能得到A: 思路:暴力枚举两个断点,然后check的时候需要字符串hash,O(1)复杂度N*N: 题目链接:传送门 #prag ...

  6. CSS3实现鼠标移动到图片上图片变大(缓慢变大,有过渡效果,放大的过程是有动画过渡的,这个过渡的时间可以自定义)

    转载自:http://blog.csdn.net/u014175572/article/details/51535768 CSS3的transform:scale()可以实现按比例放大或者缩小功能. ...

  7. laydate控制之前的日期不可选择

    laydate.render({ elem: '#start_time', min:0, //,type: 'date' //默认,可不填 }); 只要加一个min参数,就可以控制了.0表示之前的日期 ...

  8. Entity Framework框架 (一)

    1. Entity Framework的详细介绍: Entity Framework简称EF,与Asp.net关系与Ado.net关系. Entity Framework是ado.net中的一组支持开 ...

  9. 文件编码检测.ZC

    1.今天(20181101) 发现 g文件中的 xml头 和 文件编码不一致,最后发现 貌似是我搞错了,人家的文件 编码方式写的是对的. 我发现的现象是:XML里面写的是"GBK" ...

  10. Linux 端口信息查看

    //查看方法①lsof -i:端口号 用于查看某一端口的占用情况,比如查看8000端口使用情况,lsof -i:8000 lsof -i 用以显示符合条件的进程情况,lsof(list open fi ...