【刷题】洛谷 P2709 小B的询问

题目描述

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

输入输出格式

输入格式:

第一行,三个整数N、M、K。

第二行,N个整数,表示小B的序列。

接下来的M行,每行两个整数L、R。

输出格式:

M行,每行一个整数,其中第i行的整数表示第i个询问的答案。

输入输出样例

输入样例#1:

6 4 3
1 3 2 1 1 3
1 4
2 6
3 5
5 6

输出样例#1:

6
9
5
2

说明

对于全部的数据,1<=N、M、K<=50000

题解

练习一道莫队水题
加数删数的时候先把之前的贡献从当前答案里减掉,完成加删数操作后,再往答案里加个新的贡献就行了

#include<bits/stdc++.h>
#define ui unsigned int
#define ll long long
#define db double
#define ld long double
#define ull unsigned long long
const int MAXN=50000+10;
int n,m,k,cnt[MAXN],A[MAXN],Be[MAXN],unit;
ll ans[MAXN],sum;
struct node{int l,r,id;inline bool operator < (const node &A) const {return Be[l]==Be[A.l]?r<A.r:l<A.l;};
};
node query[MAXN];
template<typename T> inline void read(T &x)
{T data=0,w=1;char ch=0;while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();if(ch=='-')w=-1,ch=getchar();while(ch>='0'&&ch<='9')data=((T)data<<3)+((T)data<<1)+(ch^'0'),ch=getchar();x=data*w;
}
template<typename T> inline void write(T x,char ch='\0')
{if(x<0)putchar('-'),x=-x;if(x>9)write(x/10);putchar(x%10+'0');if(ch!='\0')putchar(ch);
}
template<typename T> inline void chkmin(T &x,T y){x=(y<x?y:x);}
template<typename T> inline void chkmax(T &x,T y){x=(y>x?y:x);}
template<typename T> inline T min(T x,T y){return x<y?x:y;}
template<typename T> inline T max(T x,T y){return x>y?x:y;}
inline void modify(int x,int k)
{sum-=1ll*cnt[x]*cnt[x];cnt[x]+=k;sum+=1ll*cnt[x]*cnt[x];
}
int main()
{read(n);read(m);read(k);unit=std::sqrt(k);for(register int i=1;i<=n;++i)read(A[i]);for(register int i=1;i<=k;++i)Be[i]=i/unit+1;for(register int i=1;i<=m;++i){read(query[i].l),read(query[i].r);query[i].id=i;}std::sort(query+1,query+m+1);int l=1,r=0;for(register int i=1;i<=m;++i){while(l<query[i].l)modify(A[l++],-1);while(l>query[i].l)modify(A[--l],1);while(r<query[i].r)modify(A[++r],1);while(r>query[i].r)modify(A[r--],-1);ans[query[i].id]=sum;}for(register int i=1;i<=m;++i)write(ans[i],'\n');return 0;
}

转载于:https://www.cnblogs.com/hongyj/p/9066398.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/414018.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

支付宝支付-当面付之扫码支付「扫码支付」

前言 支付宝支付—沙箱环境使用支付宝支付-支付宝PC端扫码支付支付宝支付-手机浏览器H5支付支付宝支付-当面付之扫码支付「本文」 当面付包含两种支付方式&#xff1a;商品条形码支付 扫码支付 经过前面两篇PC端扫码支付、手机H5支付&#xff0c;我们可以看到一个共同的特点就…

[js] 写一个格式化时间的方法

[js] 写一个格式化时间的方法 function dateToString(date, format yyyy-MM-dd) {const d new Date(date);let result format;const _config {y: d.getFullYear(),M: d.getMonth() 1, // 月d: d.getDate(), // 日h: d.getHours(), // 小时m: d.getMinutes(), // 分s: d.g…

01: awk常用

1.1 awk基本使用 1、找出当前登录用户数量 [rootlocalhost ~]# w14:09:07 up 48 min, 2 users, load average: 0.00, 0.01, 0.06 USER TTY FROM LOGIN IDLE JCPU PCPU WHAT root :0 :0 204月18 ?xdm? 59.24s 0.04s g…

MybatisCodeHelperNew-2.8.1-191-201插件使用

本文测试环境IDEA_2020.1&#xff0c;文中提供了MacOS用户操作截图 1、文件解压后放置plugs插件目录「Windows」 扫码回复「139」 下载后将文件解压&#xff0c;将压缩包内的 MyBatisCodeHelper-Pro 放入 IDEA 安装目录的 plugins 目录。 2、如果你是MacOS用户「MacOS」 同样找…

[js] pjax和ajax的区别是什么?

[js] pjax和ajax的区别是什么&#xff1f; pjax 是一个 jQuery 插件&#xff0c;它通过 ajax 和 pushState 技术提供了极速的&#xff08;无刷新 ajax 加载&#xff09;浏览体验&#xff0c;并且保持了真实的地址、网页标题&#xff0c;浏览器的后退&#xff08;前进&#xff…

Redis简单案例(四) Session的管理

Redis简单案例(四) Session的管理 原文:Redis简单案例(四) Session的管理负载均衡&#xff0c;这应该是一个永恒的话题&#xff0c;也是一个十分重要的话题。毕竟当网站成长到一定程度&#xff0c;访问量自然也是会跟着增长&#xff0c;这个时候&#xff0c; 一般都会对其进行负…

MacOS中Elasticsearch的安装「借助Homebrew」

1、Homebrew 如果你已经安装过Homebrew了&#xff0c;那么你可以跳过这一步&#xff0c;直接进行Elasticsearch安装步骤&#xff1b; Homebrew是一款MacOS平台下的软件包管理工具&#xff0c;拥有安装、卸载、更新、查看、搜索等很多实用的功能&#xff0c;强烈推荐安装。 请…

[js] 微信小程序实现轨迹回放,微信原生小程序,基于uniapp的小程序?

[js] 微信小程序实现轨迹回放&#xff0c;微信原生小程序&#xff0c;基于uniapp的小程序&#xff1f; 需要写出轨迹拖动&#xff0c;进度条&#xff0c;开始&#xff0c;暂停&#xff0c;结束功能。 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易…

负载均衡中使用 Redis 实现共享 Session

最近在研究Web架构方面的知识&#xff0c;包括数据库读写分离&#xff0c;Redis缓存和队列&#xff0c;集群&#xff0c;以及负载均衡&#xff08;LVS&#xff09;&#xff0c;今天就来先学习下我在负载均衡中遇到的问题&#xff0c;那就是session共享的问题。 一、负载均衡 负…

Typora中使用Gitee图床

1、前言 之前好友写了一篇「使用gitee作为图床 ,写markdown自动上传文件」&#xff0c;初衷是由于我一直使用的是Typora来写博客「力推」&#xff0c;但之前的版本都不支持图床功能&#xff0c;现在新版本已经有了图床功能了&#xff0c;赶紧入坑。 本篇环境&#xff1a;MacOS…

[js] 异步请求重试策略有哪些呢?

[js] 异步请求重试策略有哪些呢&#xff1f; 重试次数、重试时间间隔等个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

【NOIP2017模拟6.25】小W的动漫

题目 小W最近迷上了日本动漫&#xff0c;每天都有无数部动漫的更新等着他去看&#xff0c;所以他必须将所有的动漫排个顺序&#xff0c;当然&#xff0c;虽然有无数部动漫&#xff0c;但除了1号动漫&#xff0c;每部动漫都有且仅有一部动漫是它的前传&#xff08;父亲&#xff…

用Elasticsearch代替数据库存储日志方式

之前的项目中一直使用的是数据库表记录用户操作日志的&#xff0c;但随着时间的推移&#xff0c;数据库log单表是越来越大「不考虑删除」&#xff0c;再加上近期项目中需要用到Elasticsearch&#xff0c;所以干脆把这些用户日志迁移到ES上来了。 环境&#xff1a;SpringBoot2.2…

[js] 写一个方法实现promise失败后自动重试

[js] 写一个方法实现promise失败后自动重试 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><meta http-equiv&…

jacky解读麻省理工《计算机科学与Python编程导论》第1集

文&#xff1a;数据分析&#xff0d;jacky(朱元禄) &#xff08;一&#xff09;导言 本课程讲的中心思想就是五个字&#xff1a;计算机思维Python只是辅助工具&#xff0c;是辅助大家理解计算机思维&#xff0c;仅此而已 急功近利是人性&#xff0c;适得其反是结果&#xff1a;…

如何理解Java中的自动拆箱和自动装箱?

小伟刚毕业时面的第一家公司就被面试官给问住了&#xff0c;记忆尤深啊… 如何理解Java中的自动拆箱和自动装箱&#xff1f; 自动拆箱&#xff1f;自动装箱&#xff1f;什么鬼&#xff0c;听都没听过啊&#xff0c;这…这…知识盲区… 回到家后小伟赶紧查资料&#xff0c;我…

[js] 实现多张图片合成一张的效果

[js] 实现多张图片合成一张的效果 原理是使用canvas画布。在页面加载前 mounted方法里&#xff1a;setTimeout(() > {this.changeimg();}, 1000);changeimg( )方法&#xff1a;changeimg(){var self this;var imgsrcArray [require(../../assets/image/income/background…

chrome浏览器中解决embed标签 loop=true 背景音乐无法循环的问题。

今天试了下在html网页中加入背景音乐并设置为循环播放。一开始用<embed>标签&#xff0c;设置loop"true", 但是结果发现在IE浏览器可以&#xff0c;但是在chrome浏览器却无法实现循环&#xff0c; 播放完一次自动停止了。代码如下&#xff1a; <embed src&q…

基于Docker的Redis集群简单搭建

环境&#xff1a;Docker ( Redis:5.0.5 * 3 ) 1、拉取镜像 docker pull redis:5.0.52、创建Redis容器 创建三个 redis 容器&#xff1a; redis-node1&#xff1a;6379redis-node2&#xff1a;6380redis-node3&#xff1a;6381 docker create --name redis-node1 -v /data…

[js] ajax如何接收后台传来的图片?

[js] ajax如何接收后台传来的图片&#xff1f; 1.设置responseType为 Blob&#xff0c;2.将Blob保存为文件个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题