【CF543E】Listening to Music
【CF543E】Listening to Music
题面
题目大意
给你一个长度为\(n\)序列\(a_i\),和一个常数\(m\),定义一个函数\(f(l,x)\)为\([l,l+m-1]\)中小于\(x\)的数的个数,有\(q\)个询问,每次给定\(l,r,x\)查询\(min_{i=l}^rf(i,x)\)。
题解
先转化一个条件:
小于\(x\)的最小\(=\)大于等于\(x\)的最多
则我们就是要查询大于等于\(x\)的最多
然后再用\(m\)减去即可。
那么怎么做呢?
我们按照权值从大到小将所有位置排序
然后对于每个数,我们设它原位置在\(i\),
将左端点在原位置\(x\)时能覆盖到\(i\)的位置打上标记
依次按照值域建树,每次二分查找到最后一个大于等于查询数的
询问区间最大值即可。
\(tips:\)这题卡空间,要用到一些空间优化。
代码
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
inline int gi() {
register int data = 0, w = 1;
register char ch = 0;
while (!isdigit(ch) && ch != '-') ch = getchar();
if (ch == '-') w = -1, ch = getchar();
while (isdigit(ch)) data = 10 * data + ch - '0', ch = getchar();
return w * data;
}
typedef unsigned long long ull;
#define lson t[o].ls
#define rson t[o].rs
#define lmax (l == mid ? int(lson) : int(t[lson].mx))
#define rmax (mid + 1 == r ? int(rson) : int(t[rson].mx))
const int INF = 1e9;
const int MAX_N = 2e5 + 5;
struct Node {
ull mx : 18, ls : 23, rs : 23;
} t[MAX_N * 40];
int tot = 0, rt[MAX_N];
int modify(int p, int l, int r, int ql, int qr) {
if (l == r) { return p + 1; }
int o = ++tot; t[o] = t[p];
if (ql <= l && r <= qr) return ++t[o].mx, o;
int mid = (l + r) >> 1, tag = t[o].mx - max(lmax, rmax);
if (ql <= mid) lson = modify(t[p].ls, l, mid, ql, qr);
if (qr > mid) rson = modify(t[p].rs, mid + 1, r, ql, qr);
t[o].mx = max(lmax, rmax);
t[o].mx += tag;
return o;
}
int query(int o, int l, int r, int ql, int qr) {
if (l == r) return o;
if (ql <= l && r <= qr) return t[o].mx;
int mid = (l + r) >> 1, res = 0, tag = t[o].mx - max(lmax, rmax);
if (ql <= mid) res = max(res, query(lson, l, mid, ql, qr));
if (qr > mid) res = max(res, query(rson, mid + 1, r, ql, qr));
return res + tag;
}
int N, M;
pair<int, int> a[MAX_N];
int main () {
N = gi(), M = gi();
for (int i = 1; i <= N; i++) a[i].first = 0 - gi(), a[i].second = i;
sort(&a[1], &a[N + 1]);
for (int i = 1; i <= N; i++) {
int ql = max(1, a[i].second - M + 1);
int qr = min(a[i].second, N - M + 1);
rt[i] = modify(rt[i - 1], 1, N - M + 1, ql, qr);
}
int Q = gi(), ans = 0;
while (Q--) {
int l = gi(), r = gi(), x = gi();
x ^= ans;
int id = upper_bound(&a[1], &a[N + 1], make_pair(-x, INF)) - a - 1;
printf("%d\n", ans = M - query(rt[id], 1, N - M + 1, l, r));
}
return 0;
}
【CF543E】Listening to Music的更多相关文章
- 【复习】Listening and Reading Comprehension
短对话 M: Why do you declare the news that you're pregnant on your blog directly? W: I'm so excited tha ...
- 【转载】Python编写简易木马程序
转载来自: http://drops.wooyun.org/papers/4751?utm_source=tuicool 使用Python编写一个具有键盘记录.截屏以及通信功能的简易木马. 首先准备好 ...
- 【Android】Android 移动应用数据到SD
[Android]Android 移动应用数据到SD 在应用的menifest文件中指定就可以了,在 <manifest> 元素中包含android:installLocation 属性, ...
- JMS【二】--ActiveMQ简单介绍以及安装
现实的企业中,对于消息通信的应用一直都非常的火热,而且在J2EE的企业应用中扮演着特殊的角色,所以对于它研究是非常有必要的. 上篇博文JMS[一]--JMS基本概念,我们介绍了消息通信的规范JMS,我 ...
- 【转】adb.exe,start-server' failed -- run manually if necessary
[转]Android adb.exe程序启动不起来,如何处理 解决问题: 百度google大家多说的是任务管理器 kill掉adb 或者重启adb server,但我任务管理器就没有adb ,猜测是某 ...
- 第一阶段——CentOS6_Python3.6.1笔记(尚学堂-Python基础快速入门)+ 【补充】麦子-Python程序入门与进阶
虚拟机环境: 设置网络 .修改网络地址 .设置网卡为nat模式 .确保物理机启动dhcp.net服务 .编辑文件:vim /etc/sysconfig/network-scripts/ifcfg-et ...
- 【翻译】Flume 1.8.0 User Guide(用户指南) Processors
翻译自官网flume1.8用户指南,原文地址:Flume 1.8.0 User Guide 篇幅限制,分为以下5篇: [翻译]Flume 1.8.0 User Guide(用户指南) [翻译]Flum ...
- 【转】inotify+rsync实现实时同步
[转]inotify+rsync实现实时同步 1.1 什么是实时同步:如何实现实时同步 要利用监控服务(inotify),监控同步数据服务器目录中信息的变化 发现目录中数据产生变化,就利用rsync服 ...
- Nodejs【单机】多进程模式集群
Nodejs[单机]多进程模式集群实例: 1.安装:npm install -s cluster 2.服务代码: var debug = require('debug'); var express = ...
随机推荐
- JS实现键盘监听(包括组合键)
依然使用案例驱动~案例是学习的最好实践! <html> <head> <meta http-equiv="Content-Type" co ...
- BZOJ1468:Tree(点分治)
Description 给你一棵TREE,以及这棵树上边的距离.问有多少对点它们两者间的距离小于等于K Input N(n<=40000) 接下来n-1行边描述管道,按照题目中写的输入 接下来是 ...
- python3 安装win32api
Python3 中先安装pip install pywin32 但是在调用时任然说找不到该模块,于是查找资料后得出需要使用python -m pip install pypiwin32.
- 1、RabbitMQ入门
RabbitMQ 可以参考官网进行学习! 开发语言:Erlang – 面向并发的编程语言. AMQP:是消息队列的一个协议. mysql 是 java 写的吗?不是 那么 java 能不能访问?可以, ...
- 如何将pip更新到最新版
通过该命令即可达到目的:python -m pip install --upgrade pip pip在Python中是非常常用的,就像node.js里面的npm一样.两者共同的作用是包的管理工具.
- Java 读取properties
package Db; import java.io.InputStream; import java.util.Properties; import java.io.BufferedReader; ...
- Linux Shell常用技巧(九)
十九. 和系统运行进程相关的Shell命令: 1. 进程监控命令(ps): 要对进程进行监测和控制,首先必须要了解当前进程的情况,也就是需要查看当前进程,而ps命令就是最基本同时 ...
- 客户端对象模型之Excel数据导入到列表
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <t ...
- 修改 Hue 默认数据库
Hue 更改默认数据 1. 需要安装 mysql 一下包 mysql-server mysql-devel mysql-shared mysql-client mysql-python shared ...
- Javascript--将十进制数字转换成罗马数字显示
下午在FCC(FreeCodeCamp)中文网上做到一道练习题:将给定的数字转换成罗马数字.折磨了一个多小时,终于能把基本功能给实现了.过程如下: 关于罗马数字 罗马数字的详细介绍可见百度,或者罗马数 ...