题目链接

离别

离线算法+线段树

容易发现当我们枚举右端点r时,符合条件的左端点是一段连续的区间

我们可以用队列来维护这个连续区间的左右端点

当枚举到端点\(i\)时,将下标\(i\)插入到队列\(q[a_i]\)中

如果元素大于k,队首+1即为左端点(注意要与之前的取max)

如果元素等于k,队首即为右端点

这样对每个右端点,就找到了符合条件的左端点

然后将询问离线,以右端点排序

对于每个右端点,将符合条件的左端点插入线段树中,同时查询答案

时间复杂度\(O(nlogn)\)

(注意要开long long,还有update 与 query 都要push_down)

代码

#include <bits/stdc++.h>
#define LL long long
#define int long long
#define ls(p) p << 1
#define rs(p) p << 1|1
using namespace std;
const int N = 3e5 + 101;
int tree[N * 4], laz[N * 4];
int a[N], b[N], tl[N], tr[N];
int n, q, k, ans[N];
struct node {int id, l;};
queue<int>que[N];
vector<node>ask[N]; void push_up(int p)
{
tree[p] = tree[ls(p)] + tree[rs(p)];
}
void push_down(int p,int l,int r)
{
int mid = (l + r) / 2;
tree[ls(p)] += (mid - l + 1) * laz[p];
tree[rs(p)] += (r - mid) * laz[p];
laz[ls(p)] += laz[p];
laz[rs(p)] += laz[p];
laz[p] = 0;
} void update(int p,int l,int r,int nl,int nr,int ad)
{
if(nl <= l && r <= nr)
{
laz[p] += ad;tree[p] += (r - l + 1) * ad;
return;
}
push_down(p,l,r);
int mid = (l + r) / 2;
if(nl <= mid) update(ls(p),l,mid,nl,nr,ad);
if(nr > mid) update(rs(p),mid + 1,r,nl,nr,ad);
push_up(p);
} int query(int p,int l,int r,int nl,int nr)
{
int ans = 0;
if(nl <= l && r <= nr) return tree[p];
push_down(p,l,r);
int mid = (l + r) / 2;
if(nl <= mid) ans += query(ls(p),l,mid,nl,nr);
if(nr > mid) ans += query(rs(p),mid + 1,r,nl,nr);
return ans;
}
signed main()
{
scanf("%lld%lld%lld",&n,&q,&k);
for(int i = 1;i <= n; i++)
scanf("%lld",&a[i]);
int L = 0,R = 0; // 对应的左区间符合条件的答案
for(int i = 1;i <= n; i++)
{
que[a[i]].push(i);
if(que[a[i]].size() > k)
L = max(L,que[a[i]].front()),que[a[i]].pop(); //更新左端点
if(que[a[i]].size() == k)
R = max(R,que[a[i]].front());
tl[i] = L + 1;tr[i] = R;
}
for(int i = 1;i <= q; i++)
{
int l, r;scanf("%lld%lld",&l,&r);
ask[r].push_back((node){i,l});
}
for(int i = 1;i <= n; i++)
{
if(tl[i] <= tr[i]) update(1,1,n,tl[i],tr[i],1);
for(int j = 0;j < ask[i].size(); j++)
ans[ask[i][j].id] = query(1,1,n,ask[i][j].l,i);
}
for(int i = 1;i <= q; i++) printf("%lld\n",ans[i]);
} /*
4 4 2
1 2 3 4
1 2
1 3
1 4
2 4
*/

牛客练习赛 73 D的更多相关文章

  1. 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D

    目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...

  2. 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B

    牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...

  3. 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A

    牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...

  4. 最小生成树--牛客练习赛43-C

    牛客练习赛43-C 链接: https://ac.nowcoder.com/acm/contest/548/C 来源:牛客网 题目描述 ​ 立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 ...

  5. 牛客练习赛28-B(线段树,区间更新)

    牛客练习赛28 - B 传送门 题目 qn姐姐最好了~ ​ qn姐姐给你了一个长度为n的序列还有m次操作让你玩, ​ 1 l r 询问区间[l,r]内的元素和 ​ 2 l r 询问区间[l,r]内的 ...

  6. 牛客练习赛26:D-xor序列(线性基)

    链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...

  7. [堆+贪心]牛客练习赛40-B

    传送门:牛客练习赛40 题面: 小A手头有 n 份任务,他可以以任意顺序完成这些任务,只有完成当前的任务后,他才能做下一个任务 第 i 个任务需要花费  x_i 的时间,同时完成第 i 个任务的时间不 ...

  8. 牛客练习赛 29 E 位运算?位运算!(线段树)

    题目链接  牛客练习赛29E 对$20$位分别建立线段树.首先$1$和$2$可以合起来搞(左移右移其实是等效的) 用个lazy标记下.转移的时候加个中间变量. $3$和$4$其实就是区间$01$覆盖操 ...

  9. 牛客练习赛22C Bitset

    牛客练习赛22C 一共有 n个数,第 i 个数是 xi  xi 可以取 [li , ri] 中任意的一个值. 设 ,求 S 种类数. 感觉二进制真是一个神奇的东西. #include <iost ...

随机推荐

  1. 如何输入x的平方

    随着电脑的普及,现在都流行在电脑上做教学课件,撰写文章,尤其是理科文献,涉及的数学符号有很多,它包括了我们常见的四则运算符号和平方.立方等,也包括了高等数学中用到的积分.极限符号等,打这些公式就需要用 ...

  2. 在FL Studio中通过Key Tracking来改善声音

    FL Studio中的关键点跟踪(Key Tracking),是一种为MIDI添加更多动态效果的便利工具,在FL Studio中通过使用这个插件能力,我们无需担心自动化或手动调整参数等比较麻烦的问题. ...

  3. Vegas的软对比具体如何设置

    软对比是Vegas中比较常用的一个视频特效,通过这一特效可以让视频画面更加柔和.而对于新手用户来说,软对比显得有些陌生,不知道该如何使用. 本集主要为大家介绍:sony vegas的软对比. 在视频制 ...

  4. 【VUE】4.配置axios发起请求

    1.配置axios 1. 前端请求后端接口进行数据交互的时候,需要配置axios 2. 导入axios包, main.js import axios from 'axios' 3. 挂载到原型配置上, ...

  5. yii2.0 设置默认路由

    在config/web.php 添加 $config = [ 'defaultRoute' => 'login/login', ];

  6. kafka对接Rancher日志

    kafka对接Rancher日志 目录 kafka对接Rancher日志 概述 环境准备 正常对接kafka集群 1.helm添加bitnami库 2.下载 kafka 对应的chart压缩文件 3. ...

  7. 01-01.单一职责原则(Single Responsibility)

    1.基本介绍 对于类来说的,就是一个类,应该只负责一项职责(一个类只管一件事). 如类A负责两个不同职责:职责1,职责2. 当职责1需求变更而改变A时,可能造成职责2执行错误,所以需要将类A的粒度分解 ...

  8. C语言讲义——链表的实现

    节点(结构体描述) struct Node { int _id; char s[50]; struct Node* pre;// 指向前一个节点的地址 struct Node* next;// 指向下 ...

  9. AgileConfig-轻量级配置中心 1.1.0 发布,支持应用间配置继承

    AgileConfig轻量级配置中心自第一个版本发布不知不觉已经半年了.在并未进行什么推广的情况下收到了250个star,对我有很大的鼓舞,并且也有不少同学试用,并且给出了宝贵的意见,非常感谢他们.其 ...

  10. JZOJ 【NOIP2017提高A组模拟9.14】捕老鼠

    JZOJ [NOIP2017提高A组模拟9.14]捕老鼠 题目 Description 为了加快社会主义现代化,建设新农村,农夫约(Farmer Jo)决定给农庄里的仓库灭灭鼠.于是,猫被农夫约派去捕 ...