LOJ 6279 数列分块入门3
嗯...
题目链接:https://loj.ac/problem/6279
这道题在分块的基础上用vc数组记录,然后最后分三块,两边暴力枚举找前驱,中间lower_bound找前驱。
AC代码:
#include<cstdio>
#include<iostream>
#include<cmath>
#include<algorithm>
#include<vector> using namespace std; const int maxn = ;
const int N = ;
const int INF = 0x3f3f3f3f; int a[maxn], belong[maxn];
int L[N], R[N], add[N];
int block, num;
vector<int> vc[N]; inline void build(int n){
block = sqrt(n);
num = ceil(n * 1.0 / block);
for(int i = ; i <= n; i++){
belong[i] = (i - ) / block + ;
vc[belong[i]].push_back(a[i]);
}
for(int i = ; i <= num; i++){
L[i] = R[i - ] + ;
R[i] = i * block;
sort(vc[i].begin(), vc[i].end());
}
R[num] = n;
} inline void update(int pos){
vc[pos].clear();
for(int i = L[pos]; i <= R[pos]; i++) vc[pos].push_back(a[i]);
sort(vc[pos].begin(), vc[pos].end());
} inline void modify(int l, int r, int c){
for(int i = l; i <= min(r, R[belong[l]]); i++) a[i] += c;
update(belong[l]);
if(belong[l] != belong[r]){
for(int i = L[belong[r]]; i <= r; i++) a[i] += c;
update(belong[r]);
}
for(int i = belong[l] + ; i < belong[r]; i++) add[i] += c;
} inline int query(int l, int r, int c){
int ans = -INF;
for(int i = l; i <= min(r, R[belong[l]]); i++)
if(a[i] + add[belong[i]] < c) ans = max(ans, a[i] + add[belong[i]]);
if(belong[l] != belong[r]){
for(int i = L[belong[r]]; i <= r; i++)
if(a[i] + add[belong[i]] < c) ans = max(ans, a[i] + add[belong[i]]);
}
for(int i = belong[l] + ; i < belong[r]; i++){
if(vc[i][] + add[i] >= c) continue;
int k = lower_bound(vc[i].begin(), vc[i].end(), c - add[i]) - vc[i].begin();
ans = max(ans, vc[i][k - ] + add[i]);
}
return ans;
} int main(){
int n;
scanf("%d", &n);
for(int i = ; i <= n; i++) scanf("%d", &a[i]);
build(n);
for(int i = ; i <= n; i++){
int opt, l, r, c;
scanf("%d%d%d%d", &opt, &l, &r, &c);
if(opt == ) modify(l, r, c);
else{
int k = query(l, r, c);
if(k == -INF) printf("-1\n");
else printf("%d\n", k);
}
}
return ;
}
AC代码
LOJ 6279 数列分块入门3的更多相关文章
- LOJ #6279. 数列分块入门 3-分块(区间加法、查询区间内小于某个值x的前驱(比其小的最大元素))
#6279. 数列分块入门 3 内存限制:256 MiB时间限制:1500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 3 题目描述 给 ...
- LOJ#6279. 数列分块入门 3
区间加值还是正常的操作,查找前驱的时候用lower_bound查找,然后范围所在位置的值 #include<map> #include<set> #include<cti ...
- LOJ——#6277. 数列分块入门 1
~~推荐播客~~ 「分块」数列分块入门1 – 9 by hzwer 浅谈基础根号算法——分块 博主蒟蒻,有缘人可直接观摩以上大佬的博客... #6277. 数列分块入门 1 题目大意: 给出一个长为 ...
- loj 6278 6279 数列分块入门 2 3
参考:「分块」数列分块入门1 – 9 by hzwer 2 Description 给出一个长为\(n\)的数列,以及\(n\)个操作,操作涉及区间加法,询问区间内小于某个值\(x\)的元素个数. 思 ...
- LOJ #6285. 数列分块入门 9-分块(查询区间的最小众数)
#6285. 数列分块入门 9 内存限制:256 MiB时间限制:1500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2 题目描述 给 ...
- LOJ #6284. 数列分块入门 8-分块(区间查询等于一个数c的元素,并将这个区间的所有元素改为c)
#6284. 数列分块入门 8 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2 题目描述 给出 ...
- LOJ #6283. 数列分块入门 7-分块(区间乘法、区间加法、单点查询)
#6283. 数列分块入门 7 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 2 题目描述 给出 ...
- LOJ #6282. 数列分块入门 6-分块(单点插入、单点查询、数据随机生成)
#6282. 数列分块入门 6 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 1 题目描述 给出 ...
- LOJ #6281. 数列分块入门 5-分块(区间开方、区间求和)
#6281. 数列分块入门 5 内存限制:256 MiB时间限制:500 ms标准输入输出 题目类型:传统评测方式:文本比较 上传者: hzwer 提交提交记录统计测试数据讨论 5 题目描述 给出 ...
随机推荐
- d2admin框架学习
<template slot-scope="scope"> <el-button @click="upper_score(scope.$index, s ...
- Python—网络通信编程之tcp非阻塞通信(socketserver)
服务端代码 import socketserver # 定义一个类 class MyServer(socketserver.BaseRequestHandler): # 如果handle方法出现报错, ...
- Django_模板
1. 模板变量 小插曲 2. 模板点语法和标签 2.1 获取属性 2.2 调用方法 2.3 获取索引 2.4 获取字典中的值 3. 模板中的标签 3.1 if 3.2 for 3.3 注释 乘除 整除 ...
- SpringBoot整合Mybatis案例
SpringBoot整合Mybatis案例 2019/7/15以实习生身份入职公司前端做Angular ,但是感觉前途迷茫,于是乎学习一下Java的框架——SpringBooot. 参照大神博客:ht ...
- 初识Docker:BusyBox容器后台运行失败
1.问题描述:我在进行Docker网络实验时,使用docker run -d busybox命令时,busybox无法保持后台长期运行. ============================ ...
- JSON对比XML
相同点 纯文本 具有“自我描述性”(人类可读) 具有层级结构 可通过JavaScript解析 数据可使用AJAX传输 不同点 没有结束标签 更短 读写速度更快 能够使用内建的JavaScript ev ...
- 剑指offer 面试题38 字符串的排列
我惯用的dfs模板直接拿来套 class Solution { public: vector<string> Permutation(string str) { if(str.empty( ...
- SQL查询语句的执行
执行过程 连接器 - 管理连接,权限验证 查询缓存 - 命中缓存直接返回结果 分析器 - 词法分析 ,语法分析 优化器 - 分析执行计划,选择最优的执行计划 执行器 - 操作存储引擎接口,返回结果 不 ...
- 安装VMware Tools和设置屏幕
在虚拟机窗口的虚拟机-安装VMware Tools,点击安装,直到安装完成,出现以下界面 在主文件夹中新建VM文件夹,将VMware Tools中的VMwareTools-10.0.10-430167 ...
- 解决安装mysql时出现的三种问题
MySQL v5.0.96 for windows 安装版 链接:http://pan.baidu.com/s/1slmE2k9 密码:tadp MySQLAdministratort ...