【BZOJ3781】小B的询问

题意:有一个序列,包含N个1~K之间的整数。他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数字i在[L..R]中的重复次数

题解:初学莫队算法,差不多明白了用莫队的情况,对于这种离线的,区间长度+1时可O(1)修改答案的题,运用莫队算法是最水的

将n分成sqrt(n)块,将询问按照左端点所在的块为第一关键字,右端点的具体位置为第二关键字排序,然后用指针l,r不断暴力平移到询问的左右端点处,并不断O(1)更新答案,这样左端点的移动距离最多为sqrt(n)*m+sqrt(n)*sqrt(n)次,右端点移动距离最多为sqrt(n)*n次,所以总复杂度为O(n*sqrt(n))

对于本题,设原区间为[l,r],我们以从[l,r]平移到[l,r+1]举例,由于只差了r+1这个数,我们设r+1这个数在[l,r]里的出现的次数为c(i),那么原来这个数对答案的贡献为c(i)*c(i),加上r+1后贡献变成了(c(i)+1)*(c(i)+1),那么r+1这一个数的贡献就是2*c(i)+1,然后用它更新答案,最后c(i)++就好了

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
using namespace std;
const int maxn=50010;
typedef long long ll;
struct node
{
int qa,qb,org;
ll ans;
}q[maxn];
int n,m,siz;
ll sum;
int c[maxn];
ll s[maxn];
bool cmp(node a,node b)
{
if((a.qa-1)/siz==(b.qa-1)/siz) return a.qb<b.qb;
return (a.qa-1)/siz<(b.qa-1)/siz;
}
bool cmp2(node a,node b)
{
return a.org<b.org;
}
void add(int x)
{
sum+=2*s[c[x]]+1,s[c[x]]++;
}
void rem(int x)
{
s[c[x]]--,sum-=2*s[c[x]]+1;
}
int main()
{
int i;
scanf("%d%d%d",&n,&m,&i);
siz=(int)sqrt((double)n);
for(i=1;i<=n;i++) scanf("%d",&c[i]);
for(i=1;i<=m;i++) scanf("%d%d",&q[i].qa,&q[i].qb),q[i].org=i;
sort(q+1,q+m+1,cmp);
int l=1,r=0;
for(i=1;i<=m;i++)
{
while(r<q[i].qb) add(++r);
while(r>q[i].qb) rem(r--);
while(l<q[i].qa) rem(l++);
while(l>q[i].qa) add(--l);
q[i].ans=sum;
}
sort(q+1,q+m+1,cmp2);
for(i=1;i<=m;i++) printf("%lld\n",q[i].ans);
return 0;
}

【BZOJ2038】[2009国家集训队]小Z的袜子(hose)

题意:有n个数,m个询问,每次询问求区间[l,r]中任取两个数使得这两个数相同的概率

题解:别的和上题都一样,只不过答案变成了:(s(i)表示i出现的次数)

忽视分母,对于新加的r+1,显然贡献是s(i),然后s(i)++

这题我long long 开得好像不太对~

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
using namespace std;
const int maxn=50010;
typedef long long ll;
struct node
{
int qa,qb,ans,org;
}q[maxn];
int n,m,siz;
ll sum;
int c[maxn];
ll s[maxn];
int gcd(int a,int b)
{
return (b==0)?a:gcd(b,a%b);
}
bool cmp(node a,node b)
{
if((a.qa-1)/siz==(b.qa-1)/siz) return a.qb<b.qb;
return (a.qa-1)/siz<(b.qa-1)/siz;
}
bool cmp2(node a,node b)
{
return a.org<b.org;
}
void add(int x)
{
sum+=s[c[x]],s[c[x]]++;
}
void rem(int x)
{
s[c[x]]--,sum-=s[c[x]];
}
int main()
{
scanf("%d%d",&n,&m);
siz=(int)sqrt((double)n);
int i;
ll a,b,g;
for(i=1;i<=n;i++) scanf("%d",&c[i]);
for(i=1;i<=m;i++) scanf("%d%d",&q[i].qa,&q[i].qb),q[i].org=i;
sort(q+1,q+m+1,cmp);
int l=1,r=0;
for(i=1;i<=m;i++)
{
while(r<q[i].qb) add(++r);
while(r>q[i].qb) rem(r--);
while(l<q[i].qa) rem(l++);
while(l>q[i].qa) add(--l);
q[i].ans=sum;
}
sort(q+1,q+m+1,cmp2);
for(i=1;i<=m;i++)
{
a=q[i].ans,b=(ll)(q[i].qb-q[i].qa)*(q[i].qb-q[i].qa+1)/2,g=gcd(a,b);
if(a==0) printf("0/1\n");
else printf("%lld/%lld\n",a/g,b/g);
}
return 0;
}

【BZOJ3781、2038】莫队算法2水题的更多相关文章

  1. bzoj 2038 莫队算法

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

  2. HYSBZ 2038 莫队算法

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

  3. NBUT 1457 莫队算法 离散化

    Sona Time Limit:5000MS     Memory Limit:65535KB     64bit IO Format: Submit Status Practice NBUT 145 ...

  4. bzoj 3781 小B的询问(莫队算法)

    [题意] 若干个询问sigma{ cnt[i]^2 } cnt[i]表示i在[l,r]内的出现次数. [思路] 莫队算法,裸题. 一个cnt数组即可维护插入与删除. [代码] #include< ...

  5. [Codeforces86D]Powerful array(莫队算法)

    题意:定义K[x]为元素x在区间[l,r]内出现的次数,那么它的贡献为K[x]*K[x]*x 给定一个序列,以及一些区间询问,求每个区间的贡献 算是莫队算法膜版题,不带修改的 Code #includ ...

  6. BZOJ 4540 [Hnoi2016]序列 (单调栈 + ST表 + 莫队算法)

    题目链接  BZOJ4540 考虑莫队算法. 这题难在$[l, r]$到$[l, r+1]$的转移. 根据莫队算法的原理,这个时候答案应该加上 $cal(l, r+1) + cal(l+1, r+1) ...

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

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

  8. BZOJ 2038 小Z的袜子(hose) 莫队算法模板题

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=2038 题目大意: 作为一个生活散漫的人,小Z每天早上都要耗费很久从一堆五颜六色的袜子中 ...

  9. BZOJ 2038: [2009国家集训队]小Z的袜子(hose) 【莫队算法模版】

    任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=2038 题意概括: 有 N 只袜子(分别编号为1~N),有 M 次查询 (L, R)里面随机 ...

随机推荐

  1. TeleMCU视频会议系统添加字幕支持

    本文原创自 http://blog.csdn.net/voipmaker  转载注明出处. 最新版本号TeleMCU添加了字幕支持,与会者能够看到其它人的名字,做法是在与会者的视频上overlay 文 ...

  2. Python 算法(2) 哈夫曼编码 Huffman Encoding

    这个问题原始是用来实现一个可变长度的编码问题,但可以总结成这样一个问题,假设我们有很多的叶子节点,每个节点都有一个权值w(可以是任何有意义的数值,比如它出现的概率),我们要用这些叶子节点构造一棵树,那 ...

  3. Atititjs javascript异常处理机制与java异常的转换.js exception process

    Atititjs javascript异常处理机制与java异常的转换.js exception process 1. javascript异常处理机制 Throw str Not throw err ...

  4. Android从无知到有知——NO.5

    今天整一下利用广播实现ip拨号. 这一块主要用到的知识是android四大组件之中的一个的broadcast   receiver(广播接收者).那么它接收什么东东呢,就是我们所无谓的一个个的事件,比 ...

  5. python保存爬取的图片

    用爬虫抓取图片的保存 保存图片 request=urllib2.Request(randNumberUrl,data,headers) picture=opener.open(request).rea ...

  6. oracle 表空间 数据文件 表的关系

    数据文件是表空间的容器,增加数据文件是增大表空间的容量,而不是往表空间里添加数据因此数据文件肯定能添加,如果表空间用完了,再添加新的数据就会报错你可以这样理解,数据库是一个箱子,表空间是箱子里的抽屉, ...

  7. github上搭建网站前台页面

    其实就是把html页面提交到github,为了能在线演示: 1. 首先在github网站找到你的项目 2. 点击设置 3. 找到这几个选项,选择master branch打钩,然后保存 4. 然后就会 ...

  8. c#开源项目[转]

    一.AOP框架 Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase 独特的提供了把方面(aspects)部署到运行时代码,而其它AOP框架依赖配置文件的方式.这种部署方面(as ...

  9. 转:Linux下which、whereis、locate、find 命令的区别

    我们经常在linux要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索.这些是从网上找到的资料,因为有时很长时间不会用到,当要用的时候经常弄混了,所以放到这里方便使用. which    ...

  10. VisualStudio快捷键

    ctrl+k,c 注释选中行 ctrl+k,u 取消对选中行的注释 CTRL + SHIFT + B:生成解决方案 CTRL + F7 :生成编译 CTRL + O :打开文件 CTRL + SHIF ...