前言:

真的是不容易啊。这个题在考场上想到了最关键的性质,但是没写出来。

后来写出来,一直调,小错不断。

没想到改的最后一个错误是两个int 乘起来爆了int

其实最后我还是觉得复杂度很假。\(n^2\) 过百万。

此处对拍使用了DeepinC的代码,计算正确答案使用了硕队和张大仙的代码,感谢。

不过我感觉写的太罗嗦了,200行。

解析:

容易发现,每个建筑长高,当且仅当它左右都比它高。于是考场上我扫了一边,拿到了0分的好成绩。

因为如果这样想的话,一个建筑是可以长高多次的。假如有一个序列 \(a_1>a_2>a_3<a_4<a_5\)

那么\(a_3\)可能会长高到和旁边的\(a_2,a_4\)一样高,然后,\(a_2,a_3,a_4\)再同时长到和\(a_1,a_5\)一样高。

所以我们考虑用队列维护一下,队列中维护每个建筑(或高度相同且连续的建筑块)。每次尝试让它长高。

二次函数解析式真的挺恶心,算对称轴的时候还要扫一边这个建筑块统治的区间。(这也是我觉得复杂度很假的原因)

而且因为在左右两边的建筑,函数解析式和在中间的不一样,所以貌似需要分类讨论一下。。。

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=1000000+10,Inf=1e9+7;
int a[maxn],b[maxn];
int n,c,head,tail;
ll ans;
struct node{
int l,r,val;
node(){}
node(int x,int y,int z){
l=x;
r=y;
val=z;
}
};
queue <node> q;
void get_ans(){
for(int i=1;i<=n;++i){
int t=b[i]-a[i];
ans+=1ll*t*t;
}
for(int i=2;i<=n;++i) ans+=1ll*c*abs(b[i]-b[i-1]);
}
void Merge(){
ll d,e,t1,t2,res1,res2,f,g;
while(!q.empty()){
node t=q.front();
q.pop();
if(t.l==0&&t.r==n+1) break;
if(!(t.val<b[t.l]&&t.val<b[t.r])) continue;
if(t.l==0){
e=b[t.r]-t.val;
d=t.r-t.l-1;
t1=c;
for(int i=t.l+1;i<t.r;++i) t1-=2*(b[i]-a[i]);
t1/=(d*2);
t2=t1+1;
t1=max(0ll,min(e,t1));
t2=max(0ll,min(e,t2));
res1=-t1*c+e*c;
for(int i=t.l+1;i<t.r;++i){
ll sss1=t1+b[i]-a[i];
res1+=sss1*sss1;
}
res2=-t2*c+e*c;
for(int i=t.l+1;i<t.r;++i){
ll sss2=t2+b[i]-a[i];
res2+=sss2*sss2;
}
if(res1>res2) swap(t1,t2);
for(int i=t.l+1;i<t.r;++i) b[i]+=t1;
if(t1==e){
tail=t.r;
while(b[tail]==t.val+t1) tail++;
q.push(node(0,tail,t.val+t1));
}
}else if(t.r==n+1){
e=b[t.l]-t.val;
d=t.r-t.l-1;
t1=c;
for(int i=t.l+1;i<t.r;++i) t1-=2*(b[i]-a[i]);
t1/=(d*2);
t2=t1+1;
t1=max(0ll,min(e,t1));
t2=max(0ll,min(e,t2));
res1=-t1*c+e*c;
for(int i=t.l+1;i<t.r;++i){
ll sss1=t1+b[i]-a[i];
res1+=sss1*sss1;
}
res2=-t2*c+e*c;
for(int i=t.l+1;i<t.r;++i){
ll sss2=t2+b[i]-a[i];
res2+=sss2*sss2;
}
if(res1>res2) swap(t1,t2);
for(int i=t.l+1;i<t.r;++i) b[i]+=t1;
if(t1==e){
head=t.l;
while(b[head]==t.val+t1) head--;
q.push(node(head,n+1,t.val+t1));
}
}else{
if(b[t.l]<b[t.r]){
e=b[t.l]-t.val;
f=b[t.l]+b[t.r]-t.val*2;
d=t.r-t.l-1;
t1=c;
for(int i=t.l+1;i<t.r;++i) t1-=b[i]-a[i];
t1/=d;
t2=t1+1;
t1=max(0ll,min(e,t1));
t2=max(0ll,min(e,t2));
res1=-2*t1*c+f*c;
res2=-2*t2*c+f*c;
for(int i=t.l+1;i<t.r;++i){
ll sss1=t1+b[i]-a[i];
res1+=sss1*sss1;
}
for(int i=t.l+1;i<t.r;++i){
ll sss2=t2+b[i]-a[i];
res2+=sss2*sss2;
}
if(res1>res2) swap(t1,t2);
for(int i=t.l+1;i<t.r;++i) b[i]+=t1;
if(t1==e){
head=t.l;
while(b[head]==t.val+t1) head--;
q.push(node(head,t.r,t.val+t1));
}
}else if(b[t.l]==b[t.r]){
e=b[t.l]-t.val;
f=b[t.l]+b[t.r]-t.val*2;
d=t.r-t.l-1;
t1=c;
for(int i=t.l+1;i<t.r;++i) t1-=b[i]-a[i];
t1/=d;
t2=t1+1;
t1=max(0ll,min(e,t1));
t2=max(0ll,min(e,t2));
res1=-2*t1*c+f*c;
res2=-2*t2*c+f*c;
for(int i=t.l+1;i<t.r;++i){
ll sss1=t1+b[i]-a[i];
res1+=sss1*sss1;
}
for(int i=t.l+1;i<t.r;++i){
ll sss2=t2+b[i]-a[i];
res2+=sss2*sss2;
}
if(res1>res2) swap(t1,t2);
for(int i=t.l+1;i<t.r;++i) b[i]+=t1;
if(t1==e){
head=t.l;
tail=t.r;
while(b[head]==t.val+t1) head--;
while(b[tail]==t.val+t1) tail++;
q.push(node(head,tail,t.val+t1));
}
}else{
e=b[t.r]-t.val;
d=t.r-t.l-1;
f=b[t.l]+b[t.r]-t.val*2;
t1=c;
for(int i=t.l+1;i<t.r;++i) t1-=b[i]-a[i];
t1/=d;
t2=t1+1;
t1=max(0ll,min(e,t1));
t2=max(0ll,min(e,t2));
res1=-2*t1*c+f*c;
res2=-2*t2*c+f*c;
for(int i=t.l+1;i<t.r;++i){
ll sss1=t1+b[i]-a[i];
res1+=sss1*sss1;
}
for(int i=t.l+1;i<t.r;++i){
ll sss2=t2+b[i]-a[i];
res2+=sss2*sss2;
}
if(res1>res2) swap(t1,t2);
for(int i=t.l+1;i<t.r;++i) b[i]+=t1;
if(t1==e){
tail=t.r;
while(b[tail]==t.val+t1) tail++;
q.push(node(t.l,tail,t.val+t1));
}
}
}
}
}
void Solve(){
scanf("%d%d",&n,&c);
for(int i=1;i<=n;++i) scanf("%d",&b[i]);
b[0]=Inf;
b[n+1]=Inf;
int i=1;
while(i<=n){
int l=i-1;
int r=i+1;
while(b[r]==b[i]) r++;
q.push(node(l,r,b[i]));
i=r;
}
memcpy(a,b,sizeof(b));
a[0]=Inf;
a[n+1]=Inf;
Merge();
get_ans();
printf("%lld\n",ans);
}
int main(){
//freopen("construct.in","r",stdin);
//freopen("construct.out","w",stdout);
Solve();
return 0;
}

模拟赛18 T1 施工 题解的更多相关文章

  1. 10-18 noip提高组模拟赛(codecomb)T1倍增[未填]

    T1只想到了找环,> <倍增的思想没有学过,所以看题解看得雨里雾里的(最近真的打算学一下! 题目出的挺好的,觉得noip极有可能出现T1T2T3,所以在此mark 刚开始T1以为是模拟,还 ...

  2. 模拟赛DAY1 T1大美江湖

    这就是一个模拟题,注意1234分别对应左右上下横坐标和纵坐标的判断就好了 题解: 需要注意的是,向上取整ceil函数是对于一个double值返回一个double值,也就是说在ceil里面的类型一定要是 ...

  3. [noi.ac省选模拟赛]第12场题解集合

    题目 比赛界面. T1 数据范围明示直接\(O(n^2)\)计算,问题就在如何快速计算. 树上路径统计通常会用到差分方法.这里有两棵树,因此我们可以做"差分套差分",在 A 树上对 ...

  4. [noi.ac省选模拟赛]第10场题解集合

    题目 比赛界面. T1 不难想到,对于一个与\(k\)根棍子连接的轨道,我们可以将它拆分成\(k+1\)个点,表示这条轨道不同的\(k+1\)段. 那么,棍子就成为了点与点之间的边.可以发现,按照棍子 ...

  5. 蓝桥杯大学B组省赛2020模拟赛(一)题解与总结

    题目链接:https://www.jisuanke.com/contest/6516 A:题目: 我们称一个数是质数,而且数位中出现了 5 的数字是有趣的. 例如 5, 59, 457.求1到1000 ...

  6. DYOJ 【20220303模拟赛】最少分组 题解

    最少分组 题意 \(n\) 个点 \(m\) 条边的无向图,可以删掉 0 条或多条边,求满足条件的最小连通块数量: 对每个顶点对 \((a,b)\) ,若 \(a\) 和 \(b\) 同属于一个连通块 ...

  7. 2017.9.23 NOIP2017 金秋杯系列模拟赛 day1 T1

    回形遍历( calc .cpp/c/pas) 时间限制:1s内存 限制: 256MB [问题 描 述] 给出一个 n*m 的棋盘,按如下方式遍历,请问(x,y)往后 z 步走到的是哪个格子. [输入] ...

  8. [noi.ac省选模拟赛]第11场题解集合

    题目   比赛界面. T1   比较简单.容易想到是求鱼竿的最大独立集.由于题目的鱼竿可以被分割为二分图,就可以想到最大匹配.   尝试建边之后会发现边的数量不小,但联系题目性质会发现对于一条鱼竿,它 ...

  9. 6.29模拟赛 (T1:李时珍的皮肤衣 T2:马大嘴的废话 T3:SSY的队列 T4:清理牛棚);

    啊,又是考炸的一天,成功的退步了三名,啊,成共的看错了T1  的题意 ,水了80分. 第十五名就是我,额,已经有点倒数的感觉了,并且一道题都没AC  我太难了. 好了,废话不多说了,下面正式提接: 这 ...

随机推荐

  1. struts2执行流程和架构图

    一.struts2执行流程 二.架构图 只需要编写黄色部分的代码:

  2. 模拟BS服务器

    一.模拟BS服务器分析 二.BS模拟服务器代码实现 图片都是单独请求,后台单独线程,这边是通过构造方法传入的Runable接口的实现类匿名对象创建线程: 创建本地输入流读取到网络输出流传过来的信息再放 ...

  3. 推荐一款编程字体:Iosevka

    最近发现一款很好用的编程字体:Iosevka.它是一款现代化的编程字体集合,除了等宽.oO0 iIl1明显区分等基本特性外,还有很多非常现代的特性,比如: 多种风格:有非常多的字形可供选择,衬线/非衬 ...

  4. Spring Boot中使用@Async实现异步调用,加速任务的执行!

    什么是"异步调用"?"异步调用"对应的是"同步调用",同步调用指程序按照定义顺序依次执行,每一行程序都必须等待上一行程序执行完成之后才能执行 ...

  5. AspectJWeaver文件写入gadget详解和两种应用场景举例

    目录 0 前言 1 环境 2 gadget解析 2.1 高版本Commons-Collections的防御措施 2.2 获取AspectJWeaver的调用链 2.3 gadget详解 3 两种应用场 ...

  6. Java集合:HashMap

    Hashmap是一个存储key-value的映射表. 优点: 索引数据快,查找一个数据对的时间复杂度是O(1) 增加.删除一个数据的时间复杂度是O(1) key不能重复,可以存储一个null值 存储: ...

  7. 我们也有自带的缓存系统:PHP的APCu扩展

    想必大家都使用过 memcached 或者 redis 这类的缓存系统来做日常的缓存,或者用来抗流量,或者用来保存一些常用的热点数据,其实在小项目中,PHP 也已经为我们准备好了一套简单的缓存系统,完 ...

  8. vue中data为什么不写成data:{}这样而是写成data(){return {}}类型。

    data:{}:这样会直接挂载在vue实例中,变成全局变量,容易造成污染,再次今日该组件页面,会保留上次的变量值,不会被初始化 data(){return {}} :return包裹后数据中变量只在当 ...

  9. nginx 常用教程网址

    nginx rewrite比较齐全的教程 http://www.bubuko.com/infodetail-1810501.html

  10. Python生成桌面应用

    1.cd进入project所在根目录 2.pyinstaller -F demo.py --noconsole 3.自定义图标 选择ico格式图标发在project目录 4.pyinstaller - ...