【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 = ...
随机推荐
- BZOJ 1001 狼抓兔子 平面图的最小割
题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=1001 题目大意: 见链接 思路: 求最小割,平面图的最小割等价于对偶图的最短路 直接建 ...
- PM2 部署 nodejs 项目
在网上找到pm2.目前似乎最常见的线上部署nodejs项目的有forever,pm2这两种.使用场合: forever管理多个站点,每个站点访问量不大,不需要监控. pm2 网站访问量比较大,需要完整 ...
- size和len
size函数只能用于计算array,不能用于计算list,返回的是数组的元素个数 len函数既可以计算array,也可以计算list >>> a = np.array([1,2]) ...
- urlparse 用法
ifrom urllib2 import urlparse ‘’ captcha_id = urlparse.parse_qs(urlparse.urlparse(link).query, True) ...
- iOS App占用太多磁盘空间
问题:随着App的不断运行,发现所占磁盘空间越来越大 分析:应该是网络下载中的缓存,包括利用SDWebImage产生的.和下载单个文件被取消后的缓存 验证:查看App目录中的Tmp(系统存放未下载完成 ...
- ionic2添加支付宝插件出现问题
安装本地路径插件正常 编译正常 在打开支付页面时候 就报这个错 在手机app点击无效 错误信息: ERROR Error: Uncaught (in promise): Error: No pro ...
- sublime text3 插件安装方法
1.按Ctrl+`(ESC下方的键)调出console粘贴以下代码到底部命令行并回车 2.输入:import urllib.request,os,hashlib; h = '6f4c264a24d93 ...
- Python-type函数使用
- python学习笔记(二)python基础知识(交作业)
交作业 #!/usr/bin/env python # coding: utf-8 # # 1. 每个用户购买了多少不同种类的产品 # filename = 'train.txt' import sy ...
- Msql浅析-基础命令(二)
篇幅简介 一.Msql数据类型 1.整型 tinyint, 占 1字节 ,有符号: -128~127,无符号位 :0~255 smallint, 占 2字节 ,有符号: -32768~32767无符 ...