当前位置: 首页 > news >正文

P2709 【模板】莫队 / 小B的询问

题目描述

小 B 有一个长为 \(n\) 的整数序列 \(a\),值域为 \([1,k]\)
他一共有 \(m\) 个询问,每个询问给定一个区间 \([l,r]\),求:

\[\sum\limits_{i=1}^k c_i^2 \]

其中 \(c_i\) 表示数字 \(i\)\([l,r]\) 中的出现次数。

小 B 请你帮助他回答询问。

输入格式

第一行三个整数 \(n,m,k\)

第二行 \(n\) 个整数,表示小 B 的序列。

接下来的 \(m\) 行,每行两个整数 \(l,r\)

输出格式

输出 \(m\) 行,每行一个整数,对应一个询问的答案。

输入输出样例 #1

输入 #1

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

输出 #1

6
9
5
2

说明/提示

【数据范围】
对于 \(100\%\) 的数据,\(1\le n,m,k \le 5\times 10^4\)

题解

#include <bits/stdc++.h>
using namespace std;
const int N=1e5+10;
typedef long long ll;
int n,k,m;
struct Node
{int l,r,i;
}q[N];ll sum = 0;
int a[N];
int blen;
int bi[N];
int cnt[N];
int cl=1,cr=0;
int ans[N];bool cmp(Node a,Node b)
{if(bi[a.l]!=bi[b.l])return bi[a.l]<bi[b.l];return a.r<b.r;
}void build()
{blen = (int)sqrt(n);for(int i=1;i<=n;i++){bi[i] = (i-1)/blen +1;}sort(q+1,q+1+m,cmp);}void add(int x)
{sum -= cnt[x]*cnt[x];cnt[x]++;sum += cnt[x]*cnt[x];
}void sub(int x)
{sum -= cnt[x]*cnt[x];cnt[x]--;sum += cnt[x]*cnt[x];
}void solve()
{cin>>n>>m>>k;for(int i=1;i<=n;i++)cin>>a[i];for(int i=1;i<=m;i++){cin>>q[i].l>>q[i].r;q[i].i=i;}build();for(int i=1;i<=m;i++){int l = q[i].l;int r = q[i].r;while(cl>l){add(a[--cl]);}while(cr<r){add(a[++cr]);}while(cl<l){sub(a[cl++]);}while(cr>r){sub(a[cr--]);}ans[q[i].i] = sum;}for(int i=1;i<=m;i++)cout<<ans[i]<<'\n';
}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t=1;// cin>>t;while(t--){solve();}return 0;
}
http://www.jsqmd.com/news/54407/

相关文章:

  • 并不打算的
  • P1903 【模板】带修莫队 / [国家集训队] 数颜色 / 维护队列
  • P1883 【模板】三分 / 函数
  • CSP2025 T4
  • Day5 Scrum冲刺博客
  • 台达变频器与西门子1200 PLC互联借Modbus RTU转Profinet推动工业物联网
  • 2025-11-28
  • Convolutional Neutral Network(CNN网络)
  • 二维偏序(离线二维数点)
  • Product Hunt 每日热榜 | 2025-10-30 - 教程
  • 2025年Q4球墨铸铁管厂家TOP5排行榜:场景适配+成本优化,采购选型指南
  • 2025年Q4中国GEO优化公司权威排行榜:TOP5服务商解锁Deepseek高转化,AI搜索营销新标杆
  • WPF的MVVM模式核心架构与达成细节
  • 2025年12月GPU平台哪家好?权威榜单TOP5 低延迟+动态扩容,企业/开发者核心推荐
  • 敏捷冲刺随笔-2
  • 2025年12月高压固态软启动柜厂家排行榜,技术创新+24小时售后,工业采购测评推荐
  • 力扣160 相交链表 java达成
  • `train_test_split` 是什么?
  • 解决LVGL与FATFS编码格式冲突及外挂字库方案
  • 我是如何用浏览器插件轻松抓取抖音评论并实现精准搜索分析的
  • 重练算法(代码随想录版) day24 - 回溯part3
  • useEffect详解
  • 详解np.random.normal(0, 3, size=x.shape)
  • 代码随想录Day23_回溯_组合.md
  • 详细介绍:【JUnit实战3_21】第十二章:JUnit 5 与主流 IDE 的集成 + 第十三章:用 JUnit 5 做持续集成(上):在本地安装 Jenkins
  • 代码随想录Day24_回溯_复原IP.md
  • 何以为生
  • GraphRAG进阶:基于Neo4j与LlamaIndex的DRIFT搜索实现详解
  • Gemini3疯了!0.09接入Nano Banana Pro 4k画质API(附实战教程)
  • 11/28