牛客练习赛 73 D
题目链接
离线算法+线段树
容易发现当我们枚举右端点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的更多相关文章
- 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D
目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...
- 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B
牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...
- 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A
牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...
- 最小生成树--牛客练习赛43-C
牛客练习赛43-C 链接: https://ac.nowcoder.com/acm/contest/548/C 来源:牛客网 题目描述 立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 ...
- 牛客练习赛28-B(线段树,区间更新)
牛客练习赛28 - B 传送门 题目 qn姐姐最好了~ qn姐姐给你了一个长度为n的序列还有m次操作让你玩, 1 l r 询问区间[l,r]内的元素和 2 l r 询问区间[l,r]内的 ...
- 牛客练习赛26:D-xor序列(线性基)
链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...
- [堆+贪心]牛客练习赛40-B
传送门:牛客练习赛40 题面: 小A手头有 n 份任务,他可以以任意顺序完成这些任务,只有完成当前的任务后,他才能做下一个任务 第 i 个任务需要花费 x_i 的时间,同时完成第 i 个任务的时间不 ...
- 牛客练习赛 29 E 位运算?位运算!(线段树)
题目链接 牛客练习赛29E 对$20$位分别建立线段树.首先$1$和$2$可以合起来搞(左移右移其实是等效的) 用个lazy标记下.转移的时候加个中间变量. $3$和$4$其实就是区间$01$覆盖操 ...
- 牛客练习赛22C Bitset
牛客练习赛22C 一共有 n个数,第 i 个数是 xi xi 可以取 [li , ri] 中任意的一个值. 设 ,求 S 种类数. 感觉二进制真是一个神奇的东西. #include <iost ...
随机推荐
- 讲一讲Java的字符串常量池,看完你的思路就清晰了
前言 很多朋友Java的字符串常量池的概念困扰了很长一段时间,最近研究了一下jvm指令码,终于对它有了大概的了解. 在展示案例前,我们需要先搞清楚一个概念,众所周知,jvm的内存模型由程序计数器.虚拟 ...
- FL Studio通道常规设置
每个通道设置窗口都包含声相.音量.音高和混音音轨等.刚学习FL Studio的同学可能对这些旋钮的功能还不是很了解,所以也就直接导致了不能很好的运用.为了帮助同学进一步熟悉这款软件,小编今天将为大家详 ...
- guitar pro系列教程(十九):Guitar Pro添加音符之前我们要做什么?
前面的章节我们已经讲了不少关于{cms_selflink page='index' text='Guitar Pro'}的功能之类的讲解,那一般我们在打谱之前要做的是什么呢,很多新手玩家,对这方面也是 ...
- 牛客练习赛69 E 字串(哈希)
题目链接 题目大意 给出一个长度为n排列p 规定一个区间 [l,r] (l<=r) 是 fair 的,当且仅当区间中最小值等于 l 并且最大值等于 r 求 fair 区间的个数 题目思路 我不会 ...
- 关于uniapp无法navigateTo跳转的解决办法
今天在分包时突然无法跳转了,记个笔记 场景: 位于tabbar页面(主包)的子组件跳转到分包页面时,无法跳转 尝试办法: 使用uniapp原生跳转 uni.navigateTo({ url:'xxxx ...
- Linux服务器学习----tomcat 服务配置实验报告(一)
一.实验目的 1. 掌握 tomcat 服务的搭建 二.实验内容 1. 搭建一台缓存 tomcat 服务器 三.实验环境1. tomcat 服务器 centos7 对应主机 ip 为 10.10.64 ...
- 「刷题笔记」DP优化-状压-EX
棋盘 需要注意的几点: 题面编号都是从0开始的,所以第1行实际指的是中间那行 对\(2^{32}\)取模,其实就是\(unsigned\ int\),直接自然溢出啥事没有 棋子攻击范围不会旋转 首先, ...
- 【2020.12.01提高组模拟】A组反思
105,rk45 T1 赛时一开始先打了\(m=0\)的情况,也就是普通的卡特兰数,然后打了暴力,样例过了,把样例改改就不行了,原因没有保证是枚举的是合法的出栈序列 得分:\(WA\&TLE1 ...
- Java 生成有序 UUID
UUID.randomUUID() 生成的 UUID 是无序的,如果作为数据主键,不利于索引 Hibernate 的 UUIDHexGenerator.generate() 方法可以生成有序的 UUI ...
- 你想不到的win10快捷键
1.虚拟桌面 1.1 创建 ctrl + win + d 1.2 切换 ctrl + win + 左/右箭头 1.3 关闭 ctrl + win + f4 2. 应用窗口 2.1 打开的全部最小化 w ...