题解

很考验思维的一道题

对于不同的任务点,发现如果 \(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$的更多相关文章

  1. NOIP 模拟 $20\; \rm y$

    题解 \(by\;zj\varphi\) 首先发现一共最多只有 \(2^d\) 种道路,那么可以状压,(不要 \(dfs\),会搜索过多无用的状态) 那么设 \(f_{i,j,k}\) 为走 \(i\ ...

  2. NOIP 模拟 $20\; \rm 玩具$

    题解 \(by\;zj\varphi\) 一道概率与期望好题 对于一棵树,去掉根后所有子树就是一个森林,同理,一个森林加一个根就是一棵树 设 \(f_{i,j}\) 为有 \(i\) 个点的树,高度为 ...

  3. 7.22 NOIP模拟7

    又是炸掉的一次考试 T1.方程的解 本次考试最容易骗分的一道题,但是由于T2花的时间太多,我竟然连a+b=c都没判..暴力掉了40分. 首先a+b=c,只有一组解. 然后是a=1,b=1,答案是c-1 ...

  4. NOIP模拟 1

    NOIP模拟1,到现在时间已经比较长了.. 那天是6.14,今天7.18了 //然鹅我看着最前边缺失的模拟1,还是终于忍不住把它补上,为了保持顺序2345重新发布了一遍.. #   用  户  名   ...

  5. 20190725 NOIP模拟8

    今天起来就是虚的一批,然后7.15开始考试,整个前半个小时异常的困,然后一看题,T1一眼就看出了是KMP,但是完了,自己KMP的打法忘的一干二净,然后开始打T2,T2肝了一个tarjan点双就扔上去了 ...

  6. 20190902+0903合集-NOIP模拟

    一直没时间写QwQ 于是补一下. Day 1 晚饭吃的有点恶心…… $1s\,2s\,5s$ 还开 -O2 ?? 有点恐怖. T1 猛的一想: 把外面设成一个点, 向入口连一条权为排队时间的边 从出口 ...

  7. 2021.5.22 noip模拟1

    这场考试考得很烂 连暴力都没打好 只拿了25分,,,,,,,,好好总结 T1序列 A. 序列 题目描述 HZ每周一都要举行升旗仪式,国旗班会站成一整列整齐的向前行进. 郭神作为摄像师想要选取其中一段照 ...

  8. NOIP 模拟 $16\; \rm Lost My Music$

    题解 \(by\;zj\varphi\) 一道凸包的题 设 \(\rm dep_u\) 表示节点 \(u\) 的深度,那么原式就可化为 \(-\frac{c_v-c_u}{dep_v-dep_u}\) ...

  9. 道路 [NOIP模拟]

    Description 我们看见了一个由 m 行 n 列的 1*1 的格子组成的矩阵,每个格子(I,j)有对应的高度 h[i][j]和初始的一个非负权值 v[i][j].我们可以随便选择一个格子作为起 ...

随机推荐

  1. 滑动窗口通用解leetcode字符串匹配问题

    滑动窗口,这玩意解决一些字符串匹配的题目是真的挺好用的,虽然本质还是双指针. 思路: 1.维护一个窗口,不断的向右边移动 2.满足要求后,移动左边,当不满足时,跳出. 3.重复1,2.得出答案. 下面 ...

  2. Jmeter之代理元件&代理配置

    一 jmeter代理服务器添加及网页代理配置 1.1 打开jmeter,添加代理HTTP代理服务器,再添加一个线程组,放在代理服务器的下面. 1.2 代理服务器设置 端口默认8888,目标控制器选择t ...

  3. Mysql常用语句整理

    把工作常用的mysql命令整理一下,省的用的时候在到处找 1.常用命令 1.1 登录 mysql -u root -p 1.2 生成随机数 若在 i<=R<=j 范围内生成随机数 FLOO ...

  4. css--filter(滤镜) 属性

    前言 前段时间找工作面试官问到一个问题,你如何将一个网页整体置灰?面试遇到这样的问题,一下束手无策,之前没有接触过这样的需求,因此没有回答上来,面试结束我才知道了这是考查对 CSS3 的新属性的了解. ...

  5. Collection集合工具类

    Ⅷ.Collections 工具类 java.util.Collections Collections 集合工具类,用来对集合进行操作,部分重要方法如下: 1.public static <T& ...

  6. deepin修改数据源升级到deepin15.11桌面版

    参考:https://blog.csdn.net/baidu_41751590/article/details/89064220 1,我修改数据源地址: 换成上海交通大学源地址: http://ftp ...

  7. PAT乙级:1087 有多少不同的值 (20分)

    PAT乙级:1087 有多少不同的值 (20分) 当自然数 n 依次取 1.2.3.--.N 时,算式 ⌊n/2⌋+⌊n/3⌋+⌊n/5⌋ 有多少个不同的值?(注:⌊x⌋ 为取整函数,表示不超过 x ...

  8. erase

    erase详细解释及原理 我们先定义一个字符串string string.erase(iterator) iterator表示要删除元素的迭代器. string.erase(it_begin,it_e ...

  9. 福昕foxit phantom pdf高级编辑器企业版10.1 pro安装破解教程

    本文提供福昕foxit phantom pdf高级编辑器企业版10.1的安装教程.pj教程,可以使用全部功能,注意的是此方法对个人版无效. 没有必要再尝试别的文章,仅看这一篇即可!别的文章亲测是通过修 ...

  10. VUE SpringCloud 跨域资源共享 CORS 详解

    VUE  SpringCloud 跨域资源共享 CORS 详解 作者:  张艳涛 日期: 2020年7月28日 本篇文章主要参考:阮一峰的网络日志 » 首页 » 档案 --跨域资源共享 CORS 详解 ...