题目链接   洛古   https://www.luogu.org/problemnew/show/P1494

大概说下自己的理解

先来概率的计算公式   ∑C(2,f(i))  /  C(2,r−l+1)   f(i)是区间每种颜色袜子的数目

最后推出来的式子是 ∑f(i)*f(i)-(r−l+1)/ C(2,r−l+1)  (我也不知道怎么推的.......别人给的);

单纯的暴力就不说了  o(n*n*n);

说下和  o(n*n) 的;

莫队是 o(n*sqrt(n));

o(n*n)的算法 有两种   一是[l,r] 区间里用个小技巧   从头扫到尾   一开始ans=10;

看到第一个 1  我们+0; 看到第二个 1  我们+1; -0;第三1; +3;-1;

每次都   ans1=ans1-sum[a[j]]*(sum[a[j]]-1);   sum[a[j]]++;   ans1=ans1+sum[a[j]]*(sum[a[j]]-1);   莫队也有这个技巧

第二种是区间转移  从[a,b] 到[p, q]  a-〉p  b-q;  按照预先的排序  稍微 比o(n*n) 小一点;

莫队算法

每次区间转移都可能转移  n个数

莫队把(1-n) 分成sqrt块  每块转移       在每块里   最多 sqrt(n)+n  所以最后  sqrt(n)*(n+sqrt(n));

#include<bits/stdc++.h>
#define int long long
using namespace std;
const int maxn=5e4+;
int n,m,unit,ans;
int col[maxn],be[maxn],sum[maxn];
struct Mo { int l,r,ID,A,B; }q[maxn];
int S(int x) {return x*x; }
bool cmp(Mo a,Mo b){return be[a.l]==be[b.l]?a.r<b.r:a.l<b.l;}
bool CMP(Mo a,Mo b){return a.ID<b.ID;}
void revise(int x,int add)
{
ans-=S(sum[col[x]]);
sum[col[x]]+=add;
ans+=S(sum[col[x]]);
}
int32_t main()
{
cin>>n>>m; unit=sqrt(n);
for(int i=;i<=n;i++) cin>>col[i],be[i]=i/unit+;
for(int i=;i<=m;i++) cin>>q[i].l>>q[i].r,q[i].ID=i;
sort(q+,q+m+,cmp);
int l=;
int r=;
for(int i=;i<=m;i++)
{
// cout<<q[i].l<<" "<<q[i].r<<endl;
while(l<q[i].l)revise(l,-),l++;
while(l>q[i].l)revise(l-,),l--;
while(r<q[i].r)revise(r+,),r++;
while(r>q[i].r)revise(r,-),r--;
if(q[i].l==q[i].r){q[i].A=;q[i].B=;continue;}
q[i].A=ans-(q[i].r-q[i].l+);
q[i].B=(q[i].r-q[i].l+)*(q[i].r-q[i].l);
int c=__gcd(q[i].A,q[i].B); q[i].A=q[i].A/c; q[i].B=q[i].B/c;
}
sort(q+,q+m+,CMP);
for(int i=;i<=m;i++) printf("%lld/%lld\n",q[i].A,q[i].B);
return ;
}

莫队算法 [国家集训队]小Z的袜子的更多相关文章

  1. BZOJ 2038: [2009国家集训队]小Z的袜子(hose) [莫队算法]【学习笔记】

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 7687  Solved: 3516[Subm ...

  2. 莫队算法 2038: [2009国家集训队]小Z的袜子(hose)

    链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2038 2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 ...

  3. BZOJ2038: [2009国家集训队]小Z的袜子(hose) -- 莫队算法 ,,分块

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 3577  Solved: 1652[Subm ...

  4. BZOJ 2038: [2009国家集训队]小Z的袜子(hose)【莫队算法裸题&&学习笔记】

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 9894  Solved: 4561[Subm ...

  5. 2038: [2009国家集训队]小Z的袜子(hose) (莫队算法)

    题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=2038 专题练习: http://acm.hust.edu.cn/vjudge/conte ...

  6. kyeremal-bzoj2038-[2009国家集训队]-小z的袜子(hose)-莫队算法

    id=2038">bzoj2038-[2009国家集训队]-小z的袜子(hose) F.A.Qs Home Discuss ProblemSet Status Ranklist Con ...

  7. [BZOJ2038] [2009国家集训队]小Z的袜子(hose) 莫队算法练习

    2038: [2009国家集训队]小Z的袜子(hose) Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 10299  Solved: 4685[Sub ...

  8. 莫队算法 BOJ 2038 [2009国家集训队]小Z的袜子(hose)

    题目传送门 /* 莫队算法:求出[l, r]上取出两只相同袜子的个数. 莫队算法是离线处理一类区间不修改查询类问题的算法.如果你知道了[L,R]的答案,可以在O(1)的时间下得到 [L,R-1]和[L ...

  9. BZOJ 2038 [2009国家集训队]小Z的袜子 莫队

    2038: [2009国家集训队]小Z的袜子(hose) 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2038 Descriptionw ...

随机推荐

  1. ldap+flask+python2实现统一认证里面的那些编码神坑

    首先想吐槽下,直接接手别人的项目,而且是经过四五个人手的项目,是怎么个痛苦.两三套代码django.flask.tornado应有尽有,代码里,掰开手指头就可数的全英文注释,几台服务器没交接清楚,所有 ...

  2. bzoj3930

    题解: 莫比乌斯函数 然而向我这种弱菜肯定选择暴力dp 代码: #include<bits/stdc++.h> ,M=; typedef long long ll; using names ...

  3. 图的邻接矩阵存储实现,C++描述

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  4. 几大principal

    1.A class should have only one reason to change. 一个类只负责一件事 2.高层抽象不依赖低层实现

  5. CSS学习笔记-03- 过渡模块之前奏篇 a标签的伪类选择器

    CSS3 2D转换CSS3 3D转换CSS3 过渡CSS3 动画 CSS3 的四大金刚. 想要实现酷炫的视觉效果,上面4个是必须要掌握的.学习之前,先复习一下 视觉盛宴的前菜 :a标签的伪类选择器 铛 ...

  6. 循环神经网络-LSTM进阶

    基础的LSTM模型,单隐层,隐层单神经元,而实际中一般需要更为复杂的网络结构, 下面借用手写数字的经典案例构造比较复杂的LSTM模型,并用代码实现. 单隐层,隐层多神经元 # -*- coding:u ...

  7. 强化学习6-MC与TD的比较-实战

    # encoding:utf-8 import numpy as np import matplotlib.pylab as plt ''' 随机行走问题 0 - 1 - 2 - 3 - 4 - 5 ...

  8. Ubantu-Nginx部署

    nginx+uwsgi+django部署流程   当我们在用django开发的web项目时,开发测试过程中用到的是django自带的测试服务器,由于其安全及稳定等性能方面的局限性,django官方并不 ...

  9. IDEA发布应用时发布到lib下面的包不全

    IDEA发布应用时发布到lib下面的包不全,Tomcate启动时就报:At least one JAR was scanned for TLDs yet contained no TLDs. Enab ...

  10. Android直播实现srs流媒体服务器部署

    链接:http://blog.csdn.net/mr_sk/article/details/71086885 在配置文件中加入 pid 参数执行