莫队模板
1.并查集模板2.求质因数模板3.二分图最大匹配模板(匈牙利算法)4.欧拉函数模板5.ST表模板6.快速幂模板7.字典树模板8.矩阵模板9.Dijkstra单源最短路模板10.最近公共祖先模板(LCA)11.拓扑排序模板12.区间素数筛模板13.Kruskal和Prim模板14.树状数组模板15.二维坐标离散化模板16.单点修改区间查最值-树状数组模板17.KMP模板18.二叉搜索树模板19.DIjkstra进阶模板 路径记录 按权重(结点数最小等)记录20.判断负环模板21.Exgcd 模板22.压位高精度模板23.线段树模板24.扫描线模板
25.莫队模板
26.带修莫队模板27.SCC缩点模板28.取模+组合数29.FFT 高精度乘法模板30.字符串自然溢出哈希/单哈希/双哈希模板31.树模板32.dsu on tree 模板33.线段树模板重制34.主席树模板35.大数质因数分解模板36.线段树合并模板37.int128输入输出流38.Meissel_Lehmer模板39.浮点高精度40.自适应辛普森法41.unordered_map随机底数种子#include<bits/stdc++.h> using namespace std; using i64 = long long; const int N = 1e6 + 5; int cnt[N], a[N]; struct query { int l, r, id; }; int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int n; cin >> n; int M = sqrt(n); for (int i = 1; i <= n; i ++) cin >> a[i]; int m; cin >> m; vector<query> q(m); for (int i = 0; i < m; i ++) { int l, r; cin >> l >> r; q[i] = {l, r, i}; } //按分块大小排序,在同一个块的按块的奇偶性将右端点正序或逆序排序 sort(q.begin(), q.end(), [&M](query x, query y) { return (((x.l / M) ^ (y.l / M)) ? x.l < y.l : ((x.l / M) & 1) ? x.r<y.r: x.r>y.r); }); int l = 1, r = 0, now = 0; vector<int> ans(m); for (int i = 0; i < m; i ++) { auto [ql, qr, id] = q[i]; //易错点 while (l < ql) now -= !--cnt[a[l++]]; while (l > ql) now += !cnt[a[--l]]++; while (r < qr) now += !cnt[a[++r]]++; while (r > qr) now -= !--cnt[a[r--]]; ans[id] = now; } for (int i = 0; i < m; i ++) cout << ans[i] << "\n"; return 0; }
本文作者:Ke_scholar
本文链接:https://www.cnblogs.com/Kescholar/p/18306761
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
2023-07-17 第五次作业题解
2023-07-17 SMU Summer 2023 Contest Round 4