bzoj 3781: 小B的询问 分块
3781: 小B的询问
Time Limit: 10 Sec Memory Limit: 128 MB
Submit: 196 Solved: 135
[Submit][Status]
Description
Input
Output
Sample Input
1 3 2 1 1 3
1 4
2 6
3 5
5 6
Sample Output
9
5
2
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<vector>
#include<cmath>
using namespace std;
#define MAXN 50010
#define MAXB 300
typedef long long qword;
inline qword sqr(int x)
{
return (qword)x*x;
}
int a[MAXN];
int rcv[MAXN];
int prv[MAXN];
int tot[MAXN];
int vec[MAXB][MAXN];
int vpos[MAXN],topv=;
struct qur_t
{
int id,x,y;
qword ans;
}qur[MAXN];
bool cmp_y(qur_t q1,qur_t q2)
{
return q1.y<q2.y;
}
bool cmp_id(qur_t q1,qur_t q2)
{
return q1.id<q2.id;
}
int tarr[MAXN];
void Add_tarr(int pos,int v)
{
while (pos<MAXN)
{
tarr[pos]+=v;
pos+=pos&(-pos);
}
}
int Query_tarr(int pos)
{
int ret=;
while (pos)
{
ret+=tarr[pos];
pos-=pos&(-pos);
}
return ret;
} int main()
{
// freopen("input.txt","r",stdin);
// freopen("ouput.txt","w",stdout);
int x,y,z,n,m,t;
scanf("%d%d%d",&n,&m,&t);
for (int i=;i<=n;i++)
scanf("%d",a+i);
for (int i=;i<=n;i++)
{
prv[i]=rcv[a[i]];
rcv[a[i]]=i;
}
for (int i=;i<=n;i++)
tot[a[i]]++;
int bs=(int)sqrt(max(n,t))*;
for (int i=;i<=t;i++)
if (tot[i]>=bs)
vpos[i]=++topv;
for (int i=;i<=n;i++)
if (vpos[a[i]])
vec[vpos[a[i]]][++vec[vpos[a[i]]][]]=i;
for (int i=;i<=m;i++)
scanf("%d%d",&qur[i].x,&qur[i].y),qur[i].id=i;
sort(qur+,qur+m+,cmp_y);
int *it1,*it2;
for (int i=;i<=m;i++)
{
for (int j=;j<=topv;j++)
{
it1=lower_bound(&vec[j][],&vec[j][vec[j][]] + ,qur[i].x);
it2=upper_bound(it1,&vec[j][vec[j][]] + ,qur[i].y);
it2--;
qur[i].ans+=sqr((int)(it2-it1+));
}
}
int qnow=;
for (int i=;i<=n;i++)
{
if (!vpos[a[i]])
{
Add_tarr(i,);
x=prv[i];
while (x)
{
Add_tarr(x,);
x=prv[x];
}
}
while (qnow<=m && qur[qnow].y==i)
{
qur[qnow].ans+=Query_tarr(i)-Query_tarr(qur[qnow].x-);
qnow++;
}
}
sort(qur+,qur+m+,cmp_id);
for (int i=;i<=m;i++)
{
printf("%lld\n",qur[i].ans);
}
}
bzoj 3781: 小B的询问 分块的更多相关文章
- bzoj 3781 小B的询问——分块
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3781 非常经典的分块套路.于是时间空间比大家的莫队差了好多…… #include<io ...
- Bzoj 3781: 小B的询问 莫队,分块,暴力
3781: 小B的询问 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 426 Solved: 284[Submit][Status][Discuss ...
- BZOJ 3781: 小B的询问
3781: 小B的询问 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 643 Solved: 435[Submit][Status][Discuss ...
- 洛谷P2709 BZOJ 3781 小B的询问 (莫队)
题目描述 小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数字i在[L..R]中的重 ...
- 洛谷 P2709 BZOJ 3781 小B的询问
题目描述 小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求$\sum_1^Kc_i^2$的值,其中$c_i$表示数字i在[L..R]中的重复次数.小B请 ...
- 【模板】BZOJ 3781: 小B的询问 莫队算法
http://www.lydsy.com/JudgeOnline/problem.php?id=3781 N个数的序列,每次询问区间中每种数字出现次数的平方和,可以离线. 丢模板: #include ...
- bzoj 3781 小B的询问 —— 莫队
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3781 就是莫队,左端点分块排序,块内按右端点排序,然后直接做即可. 代码如下: #inclu ...
- bzoj 3781 小B的询问(莫队算法)
[题意] 若干个询问sigma{ cnt[i]^2 } cnt[i]表示i在[l,r]内的出现次数. [思路] 莫队算法,裸题. 一个cnt数组即可维护插入与删除. [代码] #include< ...
- BZOJ 3781: 小B的询问 [莫队]
求区间每种颜色出现次数平方和 写裸题练手 #include <iostream> #include <cstdio> #include <algorithm> #i ...
随机推荐
- 第一个html程序
<html><head><title> 表单</title> </head><body><form action=&quo ...
- Android(java)学习笔记158:Java程序入口和Android的APK入口
1.Java程序的入口:static main()方法 public class welcome extends Activity { @Override public void onCreate(B ...
- [置顶] html学习笔记,锚点,超链接,table布局,表头,h,sub,blockquote,ul,li,ol.dl,加入收藏,打印,弹出窗口
<a name="shouye"></a> <strong>strong加粗</strong> <br> 没有加粗 &l ...
- JS实现跳转到页面任何地方
要实现两个内容: 1.从A页面跳转到B页面任何地方 方法:用id对要跳转的地方进行标记. 首先,在A页面可以设一个链接 <a href = "b.html#pos" targ ...
- A Swift Tour(4) - Objects and Classes
Objects and Classes(对象和类) 用 class 关键字后面跟一个类名来创建一个class,在一个类中声明 常亮或变量,他存在于当前类的上下文,函数的方法是同样的 var numbe ...
- 转载-优秀程序员的十个tips
理解技术债务 技术债务就像信用卡一样,会有很高的利息,时间越长,修复所化的代价就越大.团队应该培养一种保证设计质量的文化,鼓励重构.同时应当鼓励其它有关代码质量的实践. 保持对原理的好奇心 做Andr ...
- java中collection、map、set、list简介 (转)
Collection接口 Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements).一些Collection允许相同的元 ...
- js单击显示元素,点击元素本身以外隐藏元素
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- Get AD user 的三种方法
一. 通过AccountManagement 程序集(System.DirectoryServices.AccountManagement) acountManagement 包含有: 1. User ...
- scrapy抓取到中文,保存到json文件为unicode,如何解决.
http://scrapy-chs.readthedocs.org/zh_CN/latest/intro/overview.html 以上链接是很好的scrapy学些资料.感谢marchtea的翻译. ...