CF86D
题解:
莫队分块
分块大小为sqrt(n)
代码:
#include<bits/stdc++.h>
using namespace std;
const int N=;
typedef long long ll;
ll a[N],cnt[N*],ans[N],res;
int n,t,L,R;
struct node{int x,y,l,p;}q[N];
int cmp(const node &x,const node &y)
{
if (x.l==y.l)return x.y<y.y;
return x.l<y.l;
}
void query(int x, int y, int flag)
{
if (flag)
{
for (int i=x;i<L;i++)
{
res+=((cnt[a[i]]<<)+)*a[i];
cnt[a[i]]++;
}
for (int i=L;i<x;i++)
{
cnt[a[i]]--;
res-=((cnt[a[i]]<<)+)*a[i];
}
for (int i=y+;i<=R;i++)
{
cnt[a[i]]--;
res-=((cnt[a[i]]<<)+)*a[i];
}
for (int i=R+;i<=y;i++)
{
res+=((cnt[a[i]]<<)+)*a[i];
cnt[a[i]]++;
}
}
else
for (int i=x;i<=y;i++)
{
res+=((cnt[a[i]]<<)+)*a[i];
cnt[a[i]]++;
}
L=x;R=y;
}
int main()
{
scanf("%d%d",&n,&t);
for (int i=;i<=n;i++)scanf("%I64d", &a[i]);
int block_size=sqrt(n);
for (int i=;i<t;i++)
{
scanf("%d%d",&q[i].x,&q[i].y);
q[i].l=(q[i].x-)/block_size;
q[i].p=i;
}
sort(q,q+t,cmp);
memset(cnt,,sizeof(cnt));
res=;
for (int i=;i<t;i++)
{
query(q[i].x,q[i].y,i);
ans[q[i].p]=res;
}
for (int i=;i<t;i++)printf("%I64d\n",ans[i]);
return ;
}
CF86D的更多相关文章
- 【题解】Luogu CF86D Powerful array
原题传送门 裸的莫队啊,我博客里有对莫队较详细的介绍 这道题很简单,可以说是裸的模板 但是如何在已有的值上进行操作? 小学生应该都知道 那么转移就超级简单了qaq inline void add(re ...
- CF86D Powerful array
题意翻译 题意:给出一个n个数组成的数列a,有t次询问,每次询问为一个[l,r]的区间,求区间内每种数字出现次数的平方×数字的值 的和. 输入:第一行2个正整数n,t. 接下来一行n个正整数,表示数列 ...
- 「CF86D」Powerful array 解题报告
题面 给出一个\(n\)个数组成的数列\(a\),有\(t\)次询问,每次询问为一个\([l,r]\)的区间,求区间内每种数字出现次数的平方×数字的值 的和 思路: 直接上莫队咯 然后就T了 没学过莫 ...
随机推荐
- Redundant Paths---poj3177(双连通分量)
题目链接:http://poj.org/problem?id=3177 题意:有n个牧场,Bessie 要从一个牧场到另一个牧场,要求至少要有2条独立的路可以走.现已有m条路,求至少要新建多少条路,使 ...
- Python开发【模块】:M2Crypto RSA加密、解密
M2Crypto 模块 快速安装: # 环境centos7.0,提前装好openssl(自行百度安装),windows装不上,暂不考虑了 [root@localhost ~]# pip install ...
- django 多数据分库
路由策略 # -*- coding: utf-8 -*- from django.conf import settings class DatabaseAppsRouter(object): &quo ...
- Controller中返回数据总结(ResponseEntity,@ResponseBody,@ResponseStatus)
在传统的开发过程中,我们的控制CONTROLLER层通常需要转向一个JSP视图:但随着WEB2.0相关技术的崛起,我们很多时候只需要返回数据即可,而不是一个JSP页面. ResponseEntity: ...
- C# 反双曲余弦函数
反双曲余弦函数的定义是: T1 = Math.Log(t + Math.Sqrt(t * t - 1)); 1. 叉乘(cross product),也叫向量的外积.向量积.顾名思义,求下来的结果是一 ...
- 使用Rxjava自己创建RxBus
https://piercezaifman.com/how-to-make-an-event-bus-with-rxjava-and-rxandroid/ https://lingyunzhu.git ...
- raspberry pi 树莓派作为比特比矿机
http://www.instructables.com/id/Bitcoin-Mining-using-Raspberry-Pi/ Step 5: Installing Required Libra ...
- word安装mathtype
1:window版本的mathtype:https://pan.baidu.com/s/1Yn8kPG9Y9nBPGaotFJaL2Q ,密码spwm 2:点击exe安装 (安装到c盘,将不会出 ...
- PHP debug_backtrace() 函数打印调用处的调试信息
http://php.net/manual/zh/function.debug-backtrace.php debug_backtrace (PHP 4 >= 4.3.0, PHP 5, PHP ...
- RedHat Linux文本模式下乱码解决方法
如果在安装RedHat Linux时选择中文未缺省语言,在文本模式下会出现乱码情况,对于在CLI(command-line interface,命令行界面)方式下调试程序时诸多不便,因为出错信息全是乱 ...