CF1601E Phys Ed Online
考虑一个贪心。
我们一定采取的方案是
\(b_i = \min_{j = i - k}^i a_j\)
\(\sum a_l + b_{l + k} + \min_{i = 1}^2{b_{l + ik}} + \min_{i = 1}^3{b_{l + ik}}......\min_{i = 1}^t{b_{l + ik}}\)
那么我们看出来可以只考虑同余系的关键点即可。
但是我们发现我们不好计算答案。
一个想要的考虑是扫描线。
但是我们发现这样需要支持区间加,区间取 \(0\),区间加等差数列,单点查。
然后我发现我不会区间加等差数列,所以只能考虑正解做法。
考虑我们差分答案,记\(f_i\)为一直到结尾的答案,考虑倒序枚举\(i\),直接单调栈,其转移显然。
那么\([l,r]\)答案应为\(f_i - f_p + b_p * {(r - p + 1)} + a_l\)
\(p\)为\([l,r]\)中最小值位置。
考虑笛卡尔树上的\([l,r]\)的最小值位置即其两点\(LCA\)位置。
那么复杂度为\(O(nlog{\frac{n}{k}} + q)\)
较正解做法\(O(nlog + q)\) 效率应该差距不大。
所以这里采用正解做法即ST表。
#include<bits/stdc++.h>
#define ll long long
#define N 600005
#define int ll
int n,q,k;
std::pair<int,int> g[N][30];//ST表
int lg[N],b[N];
std::pair<int,int> get(int l,int r){
if(l > r)
return std::pair<int,int>(0,0);
int p = lg[r - l + 1];
return std::min(g[l][p],g[r - (1ll << p) + 1][p]);
}
int stk[N],top,nxt[N],f[N];
ll calc(int l,int r){
int p = get(l - k,r).second;
int tmp = g[p][0].first;
if(p == l - k)
p += k;
p = p + (r - p) % k;
return f[l] - f[p] + (r / k - p / k + 1) * b[p];
}
signed main(){
scanf("%d%d%d",&n,&q,&k);
lg[0] = -1;
for(int i = 1;i <= n;++i)
lg[i] = lg[i / 2] + 1;
for(int i = 1;i <= n;++i){
scanf("%d",&g[i][0].first);
g[i][0].second = i;
}
for(int j = 1;j <= 20;++j)
for(int i = 1;i + (1ll << j) - 1 <= n;++i)
g[i][j] = std::min(g[i][j - 1],g[i + (1ll << (j - 1))][j - 1]);
for(int i = k + 1;i <= n;++i)
b[i] = get(i - k,i).first;
for(int l = k + 1;l + k <= n && l <= 2 * k;++l){
int r = l + (n - l) / k * k;
top = 1;
for(int i = r;i >= l;i -= k){
while(top > 1 && b[i] <= b[stk[top]])
top -- ;
nxt[i] = stk[top];
f[i] = f[nxt[i]] + b[i] * (nxt[i] / k - i / k);
stk[++top] = i;
}
}
while(q -- ){
int l,r;
scanf("%d%d",&l,&r);
r = l + (r - l) / k * k;
std::cout<<(1ll * g[l][0].first + 1ll * (l + k <= r? calc(l + k,r) : 0))<<std::endl;
}
}
CF1601E Phys Ed Online的更多相关文章
- 贪心/构造/DP 杂题选做Ⅲ
颓!颓!颓!(bushi 前传: 贪心/构造/DP 杂题选做 贪心/构造/DP 杂题选做Ⅱ 51. CF758E Broken Tree 讲个笑话,这道题是 11.3 模拟赛的 T2,模拟赛里那道题的 ...
- EDdb 是ED数据
eddb 是ED数据统计汇总软件的简称,用于统计汇总企事业单位的各类信息数据. 采用Excel界面,操作简单. 对各类信息数据,均可以自定义数据格式,通过internet联网,收集各类信息数据,并通 ...
- ios CoreBluetooth 警告 is being dealloc'ed while pending connection
ios CoreBluetooth 警告 is being dealloc'ed while pending connection CoreBluetooth[WARNING] <CBPerip ...
- ed编辑器使用
evilxr@IdeaPad:/tmp$ ed aa.c 0 a enter another words hello nice www.evilxr.com . w aa.c 46 q a 表示添加内 ...
- Linux ed命令
$ ed <- 激活 ed 命令 a <- 告诉 ed 我要编辑新文件 My name is Titan. <- 输入第 ...
- ED/EP系列5《消费指令》
1. 消费交易 消费交易允许持卡人使用电子存折或电子钱包的余额进行购物或获取服务. 特点: 1) --可以在销售点终端(POS)上脱机进行 2) --使用电子存折进行的消费交易必须提交个人识别码(PI ...
- ED/EP系列4《圈存指令》
1. 圈存交易 通过圈存交易,持卡人可将其在银行相应账户上的资金划入电子存折或电子钱包中. 特点: 1)--必须在金融终端上联机进行; 2)--必须提交个人识别码(PIN) 步骤: 1) --终端: ...
- ED/EP系列1《简介》
电子存折(ED:ElectronicDeposit)一种为持卡人进行消费.取现等交易而设计的支持个人识别码(PIN)保护的金融IC卡应用.它支持圈存.圈提.消费和取现等交易. 电子钱包(EP:Elec ...
- ED/EP简介
ED:electronic Deposit,电子存折 EP:electronic Purse,电子钱包 PIN:personal identification number,个人识别码 MAC:Mes ...
随机推荐
- RabbitMQ延时队列应用场景
应用场景 我们系统未付款的订单,超过一定时间后,需要系统自动取消订单并释放占有物品 常用的方案 就是利用Spring schedule定时任务,轮询检查数据库 但是会消耗系统内存,增加了数据库的压力. ...
- SharkCTF2021 The_nature_of_the_human
(信安数基的quiz1写不出来 来这放题解泄愤) crypto类题. 题面 其加密的大致过程是,对明文flag中的逐个字符,随机使用三种加密方式: 第一种,对该字符进行sha256加密后以16进制形式 ...
- 《Spring源码深度解析》学习笔记——Spring的整体架构与容器的基本实现
pring框架是一个分层架构,它包含一系列的功能要素,并被分为大约20个模块,如下图所示 这些模块被总结为以下几个部分: Core Container Core Container(核心容器)包含有C ...
- AIApe问答机器人Scrum Meeting 5.3
Scrum Meeting 6 日期:2021年5月3日 会议主要内容概述:汇报两日工作. 一.进度情况 组员 负责 两日内已完成的工作 后两日计划完成的工作 工作中遇到的困难 李明昕 后端 与前端对 ...
- Mac 系统如何利用软链接在根目录创建文件夹?
作者:泥瓦匠 出处:https://www.bysocket.com/2021-10-26/mac-create-files-from-the-root-directory.html Mac 操作系统 ...
- 从0到1使用Kubernetes系列(四):搭建第一个应用程序
传统Kubernetes应用搭建 创建Namespace 在一个Kubernetes集群中可以创建多个Namespace进行"环境隔离",当项目和人员众多的时候,可以考虑根据项目的 ...
- 21.6.23 test
省选 模拟赛 今天考的是一套题目背景和描述会被[数据删除]的模拟赛. 犯了几个傻逼错. \(T1\) 把两种情况的概率看反了,写的暴力.\(35->5\) pts. \(T2\) 以为想到了正解 ...
- Vulnstack内网靶场3
Vulnstack内网靶场3 (qiyuanxuetang.net) 环境配置 打开虚拟机镜像为挂起状态,第一时间进行快照,部分服务未做自启,重启后无法自动运行. 挂起状态,账号已默认登陆,cento ...
- Gitlab-CI使用及.gitlab-ci.yml配置入门一篇就够了
转载:Gitlab-CI使用及.gitlab-ci.yml配置入门一篇就够了 - 简书 (jianshu.com) 一. Gitlab-CI/CD使用场景 首先,公司使用Gitlab作为工作仓库进行代 ...
- Ubuntu Python2 和 Python3 共存 切换
例如 你写了代码 创建一个文件 在终端 vim test.py 然后写入代码 print "hello world" 接着运行代码 python test.py 会输出 hello ...