NOIP 模拟 $20\; \rm z$
题解
很考验思维的一道题
对于不同的任务点,发现如果 \(x_{i-1}<x_i<x_{i+1}\) 或 \(x_{i-1}>x_i>x_{i+1}\) 那么 \(x_i\) 这个位置的数就没用了
将序列先扫一遍,合并不同的位置,然后将合并后的 \(x_i->x_{i+1}\) 按距离排序,再将询问序列从小到大排序,离线询问
用一个 \(map\) 存储所有 \(x_{i}->x_{i+1}\) 的任务编号,二分查找当前点
那么当一个长度大于这段区间了,它就会超出范围,要将它左右的区间和它合并
注意:ans[c[t].id]=calc(ans[c[t].l),t++ 不能写成 ans[c[t].id]=calc(ans[c[t++].l),因为在高版本 c++ 中是从右往左编译的
Code
#include<bits/stdc++.h>
#define ri register signed
#define p(i) ++i
using namespace std;
namespace IO{
char buf[1<<21],*p1=buf,*p2=buf;
#define gc() p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++
template<typename T>inline void read(T &x) {
ri f=1;x=0;register char ch=gc();
while(ch<'0'||ch>'9') {if (ch=='-') f=0;ch=gc();}
while(ch>='0'&&ch<='9') {x=(x<<1)+(x<<3)+(ch^48);ch=gc();}
x=f?x:-x;
}
}
using IO::read;
namespace nanfeng{
#define node(id,x) (node){id,x}
#define FI FILE *IN
#define FO FILE *OUT
template<typename T>inline T cmax(T x,T y) {return x>y?x:y;}
template<typename T>inline T cmin(T x,T y) {return x>y?y:x;}
typedef long long ll;
static const int N=1e5+7;
struct node{int id;ll x;}al[N];
inline int operator<(const node &n1,const node &n2) {return n1.x>n2.x;}
inline int cmp(node n1,node n2) {return n1.x<n2.x;}
priority_queue<node> que;
map<int,int> mp;
int n,q,cnt,t=1;
ll sum,dx[N],ans[N];
inline ll calc(ll l) {
if (mp.empty()) return 0;
if (mp.begin()->second<0) return sum-(mp.size()-1)*l;
return sum-mp.size()*l;
}
inline int main() {
// FI=freopen("nanfeng.in","r",stdin);
// FO=freopen("nanfeng.out","w",stdout);
read(n),read(q);
ri lst=0;
for (ri i(1),x;i<=n;p(i)) {
read(x);
if (x==lst) continue;
if (cnt&&(dx[cnt]<0&&x-lst<0||dx[cnt]>0&&x-lst>0)) dx[cnt]+=x-lst;
else dx[p(cnt)]=x-lst;
lst=x;
}
for (ri i(1),l;i<=q;p(i)) read(l),al[i].x=l,al[i].id=i;
sort(al+1,al+q+1,cmp);
for (ri i(1);i<=cnt;p(i)) {
sum+=abs(dx[i]);
mp[i]=dx[i];
que.push(node(i,abs(dx[i])));
}
while(!que.empty()) {
node tmp=que.top();que.pop();
auto it=mp.lower_bound(tmp.id);
if (it==mp.end()) continue;
node nw=node(it->first,it->second);
if (abs(nw.x)!=tmp.x||nw.id!=tmp.id) continue;
while(t<=q&&tmp.x>al[t].x) ans[al[t].id]=calc(al[t++].x);
auto bg=mp.begin();
if (it!=mp.begin()) {
if (it!=prev(mp.end())) {
auto pr=prev(it),nx=next(it);
node tmpr=node(pr->first,pr->second);
node tmpn=node(nx->first,nx->second);
mp.erase(pr);mp.erase(nx);
sum-=abs(nw.x);
sum-=abs(tmpr.x);
sum-=abs(tmpn.x);
tmp.x=nw.x;
tmp.x+=tmpr.x;
tmp.x+=tmpn.x;
it->second=tmp.x;
tmp.x=abs(tmp.x);
sum+=tmp.x;
que.push(tmp);
} else {
sum-=abs(nw.x);
mp.erase(it);
}
} else {
if (nw.x>0) {
if (it!=prev(mp.end())) {
auto nx=next(it);
node tmpn=node(nx->first,nx->second);
mp.erase(nx);
sum-=abs(nw.x);
sum-=abs(tmpn.x);
tmp.x=nw.x;
tmp.x+=tmpn.x;
if (tmp.x) {
it->second=tmp.x;
tmp.x=abs(tmp.x);
sum+=tmp.x;
que.push(tmp);
} else mp.erase(it);
} else {
sum-=abs(tmp.x);
mp.erase(it);
}
}
}
}
while(t<=q) ans[al[t].id]=calc(al[t++].x);
for (ri i(1);i<=q;p(i)) printf("%lld\n",ans[i]);
return 0;
}
}
int main() {return nanfeng::main();}
NOIP 模拟 $20\; \rm z$的更多相关文章
- NOIP 模拟 $20\; \rm y$
题解 \(by\;zj\varphi\) 首先发现一共最多只有 \(2^d\) 种道路,那么可以状压,(不要 \(dfs\),会搜索过多无用的状态) 那么设 \(f_{i,j,k}\) 为走 \(i\ ...
- NOIP 模拟 $20\; \rm 玩具$
题解 \(by\;zj\varphi\) 一道概率与期望好题 对于一棵树,去掉根后所有子树就是一个森林,同理,一个森林加一个根就是一棵树 设 \(f_{i,j}\) 为有 \(i\) 个点的树,高度为 ...
- 7.22 NOIP模拟7
又是炸掉的一次考试 T1.方程的解 本次考试最容易骗分的一道题,但是由于T2花的时间太多,我竟然连a+b=c都没判..暴力掉了40分. 首先a+b=c,只有一组解. 然后是a=1,b=1,答案是c-1 ...
- NOIP模拟 1
NOIP模拟1,到现在时间已经比较长了.. 那天是6.14,今天7.18了 //然鹅我看着最前边缺失的模拟1,还是终于忍不住把它补上,为了保持顺序2345重新发布了一遍.. # 用 户 名 ...
- 20190725 NOIP模拟8
今天起来就是虚的一批,然后7.15开始考试,整个前半个小时异常的困,然后一看题,T1一眼就看出了是KMP,但是完了,自己KMP的打法忘的一干二净,然后开始打T2,T2肝了一个tarjan点双就扔上去了 ...
- 20190902+0903合集-NOIP模拟
一直没时间写QwQ 于是补一下. Day 1 晚饭吃的有点恶心…… $1s\,2s\,5s$ 还开 -O2 ?? 有点恐怖. T1 猛的一想: 把外面设成一个点, 向入口连一条权为排队时间的边 从出口 ...
- 2021.5.22 noip模拟1
这场考试考得很烂 连暴力都没打好 只拿了25分,,,,,,,,好好总结 T1序列 A. 序列 题目描述 HZ每周一都要举行升旗仪式,国旗班会站成一整列整齐的向前行进. 郭神作为摄像师想要选取其中一段照 ...
- NOIP 模拟 $16\; \rm Lost My Music$
题解 \(by\;zj\varphi\) 一道凸包的题 设 \(\rm dep_u\) 表示节点 \(u\) 的深度,那么原式就可化为 \(-\frac{c_v-c_u}{dep_v-dep_u}\) ...
- 道路 [NOIP模拟]
Description 我们看见了一个由 m 行 n 列的 1*1 的格子组成的矩阵,每个格子(I,j)有对应的高度 h[i][j]和初始的一个非负权值 v[i][j].我们可以随便选择一个格子作为起 ...
随机推荐
- 两个字符串,s1 包含 s2,包含多次,返回每一个匹配到的索引---python
#两个字符串,s1 包含 s2,包含多次,返回每一个匹配到的索引 def findSubIndex(str1,subStr): str_len = len(str1) sub_len = len(su ...
- libcurl库(C++)快速使用
---恢复内容开始--- libcurl是一个跨平台的网络协议库,支持http, https, ftp, gopher, telnet, dict, file, 和ldap 协议.libcurl同样支 ...
- nodejs安装+vue安装
一.nodejs安装 电脑win7的,nodejs V12.16.2以前的版本支持win7 nodejs下载地址: http://mirrors.nju.edu.cn/nodejs/v12.15.0/ ...
- Python使用笔记27--mysql操作封装类
1.面向过程 1 import pymysql 2 3 #面向过程 4 mysql_info = {'host':'127.0.0.1', 5 'port':3306, 6 'user':'root' ...
- python使用笔记23--面向对象编程
1.面向对象编程概念 面向对象是包含面向过程 面向过程编程 买车: 1.4s看车,买车 2.上保险 保险公司 3.交税 地税局 4.交管所 上牌 面向对象编程 卖车处: 1.4s 2.保险 3.交税 ...
- Caffeine缓存的简单介绍
1.简介 在本文中,我们将了解Caffeine,一个用于Java的高性能缓存库. 缓存和Map之间的一个根本区别是缓存会清理存储的项目. 一个清理策略会决定在某个给定时间哪些对象应该被删除,这个策略直 ...
- asp.net 简明代码
<asp:RadioButton ID="daadaa" runat="server" GroupName="dada" OnChec ...
- static能修饰什么
简洁易懂讲清原理,讲不清你来打我~ 修饰普通变量,修改变量的存储区域和生命周期,使变量存储在静态区,在main函数运行前就分配空间,有初始值就初始值,没有初始值就系统默认值初始化 修饰普通函数,修改函 ...
- lis分析之一一批处理(任务)如何连接数据库的
public class ZFBCheckAccountTask extends TaskThread { } 这个类运行时候自动加载了数据库连接,不明白是如何提前加载的,开始用static { } ...
- Intouch/ifix语音报警系统制作(2)
在我的先前一篇关于语音报警系统制作的文章中,阐述了如何通过标签组来获得@name@的详细内容,以通过这种方式来进行详细的设备故障播报.经过一段时间的试运行,发现使用标签组的方式会产生较大的耦合,(即当 ...