题解-BOI 2004 Sequence

Problem

bzoj & Luogu

题目大意:

给定序列\(\{a_i\}\),求一个严格递增序列\(\{b_i\}\),使得\(\sum \bigl |a_i-b_i\bigr|\)最小

Thought

正序:直接对应
逆序:取中位数(证明:“医院设置”)
最优解一定是分段
每一段台阶式上升
每一段选取中位数
沙漏型左偏树 合并区间 选取中位数
upd:貌似不需要沙漏型?

Solution

前置技能:小学奥数、可并堆

和上面类似,先不考虑严格上升,即先考虑非严格上升

序列一定是要分成若干段,每一段的\(b\)值相等,且后一段比前一段大,像台阶一样(如下图,是一个\(b(x)\)的伪函数)

1428579-20180628175256062-16221207.jpg

先令\(\forall i\in[1,n],a_i=b_i\),这样的答案为零,但却不合法,接下来考虑如何用最小代价使答案合法,考虑对于相邻两段数:

设当前前一段取最优值时的\(b\)统一为\(b_1\),后一段统一为\(b_2\),变换之后两者的统一\(b\)值分别变为\(b_1^{'},b_2^{'}\)

如果\(b_1\leq b_2\),则对于这两段来说是合法的,无需操作;

如果\(b_1>b_2\),则表示因为要求\(b_1\leq b_2\),而现在是\(b_1>b_2\),要求\(b_1^{'}\leq b_2^{'}\),考虑到两段的\(b\)变化得越少越好,即\(\bigl | b_1-b_1^{'}\bigr |,\bigl | b_1-b_1^{'}\bigr |\)取最小,则变换之后\(b_1^{'}=b_2^{'}\),我们再考虑\(b_1^{'}(b_2^{'})\)的取值,应为这两段数合在一起的中位数,证明见下方“附”,找中位数可以用线段树解决,也可以用堆解决(堆解法见TJOI2010中位数),考虑到两段需要合并,线段树需要线段树合并,而堆只需要可并堆即可

如何把相邻两段的处理扩展到整个序列呢,鉴于整个\(b\)序列是递增的,可以用单调栈实现,栈中的比较方式就是上述对于相邻两段的处理

现在解除一开始自己设置的限制,将\(a_i\)设为\(a_i-i\)即可将非严格上升序列的做法转移到严格上升序列的做法

附:证明:其实就是小学奥数题 对于一段数\(\{c_i\}\)选取\(x\)使得\(\sum \bigl |x-c_i \bigr |\),最小的\(x\)值的一个取值为\(\{c_i\}\)序列的中位数:

反证法:设原序列有\(n\)个元素,则比\(x\)大/小的数有\(\frac n2\)个,若\(x\)变小或变大,则若越过序列中另一个值时,比\(x\)大/小的数有\(\frac n2±1\)个,统计答案时只会增加\(2\)或不变

Code

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
#define rg registerstruct ios {inline char read(){static const int IN_LEN=1<<18|1;static char buf[IN_LEN],*s,*t;return (s==t)&&(t=(s=buf)+fread(buf,1,IN_LEN,stdin)),s==t?-1:*s++;}template <typename _Tp> inline ios & operator >> (_Tp&x){static char c11,boo;for(c11=read(),boo=0;!isdigit(c11);c11=read()){if(c11==-1)return *this;boo|=c11=='-';}for(x=0;isdigit(c11);c11=read())x=x*10+(c11^'0');boo&&(x=-x);return *this;}
} io;const int N=1001000;
struct Leftist_Tree{int l,r,dis,val;}t[N];
struct node{int l,r,rt,sz,val;node(){}node(const int&L,const int&id){l=L,r=rt=id,sz=1,val=t[id].val;}
}h[N];
int n,top;inline int merge(int u,int v){if(!u||!v)return u|v;if(t[u].val<t[v].val||(t[u].val==t[v].val&&u>v))swap(u,v);int&l=t[u].l,&r=t[u].r;r=merge(r,v);if(t[l].dis<t[r].dis)swap(l,r);t[u].dis=t[r].dis+1;return u;
}inline int del(int u){return merge(t[u].l,t[u].r);}void work(){io>>n;for(rg int i=1;i<=n;++i)io>>t[i].val,t[i].val-=i;h[top=1]=node(1,1);for(rg int i=2;i<=n;++i){int l=h[top].r+1;h[++top]=node(l,i);while(top^1&&h[top-1].val>h[top].val){--top;h[top].rt=merge(h[top].rt,h[top+1].rt);h[top].r=h[top+1].r;h[top].sz+=h[top+1].sz;while(h[top].sz>((h[top].r-h[top].l+2)>>1)){--h[top].sz;h[top].rt=del(h[top].rt);}h[top].val=t[h[top].rt].val;}}return ;
}void Print(){ll Ans=0;for(rg int i=1,p=1;i<=n;++i){if(i>h[p].r)++p;Ans+=abs(h[p].val-t[i].val);}printf("%lld\n",Ans);for(rg int i=1,p=1;i<=n;++i){if(i>h[p].r)++p;printf("%d ",h[p].val+i);}putchar('\n');return ;
}int main(){work();Print();return 0;
}

转载于:https://www.cnblogs.com/penth/p/9239977.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/250024.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【vscode】编译java时报错乱码

报错如下 解决方案 改变终端的编码格式 chcp 946注意: chcp 65001 UTF-8编码chcp 936 GBK2312代码页

搭建集群架构

环境搭建进行规划(磨刀不误砍柴工). 集群架构组成说明. 负载均衡服务器使用Nginx做搭建,(nginx反向代理软件) Nginx01<-------->Nginx02 3台Web网站服务器,Nginx网站web服务功能 2台负载均衡服务器 (对网站的流量进行分流,减少流量对某台服务器的压力) 3台web服务器, (处…

Model、ModelMap和ModelAndView的使用详解

1.前言 最近SSM框架开发web项目&#xff0c;用得比较火热。spring-MVC肯定用过&#xff0c;在请求处理方法可出现和返回的参数类型中&#xff0c;最重要就是Model和ModelAndView了&#xff0c;对于MVC框架&#xff0c;控制器Controller执行业务逻辑&#xff0c;用于产生模型数据…

【mysql】- 初始化

参考 1、写配置文件 在mysql的根目录下创建 my.ini&#xff0c;根目录的截图和输入的内容如下所示。 my.ini的内容如下 [mysql] default-character-setutf8[mysqld] character-set-serverutf8 default-storage-engineINNODB sql_modeSTRICT_TRANS_TABLES,NO_ZERO_IN_DATE,…

【FBI WARNING】一些Noip的黑科技 持续整理!

有疑问或错误尽管评论&#xff01;&#xff01; 下面以C为准。 本文手&#xff08;粘&#xff09;打&#xff08;贴&#xff09;于各大博客之间 有问题。。。。。 我也不懂 max、min的优化 我们知道&#xff0c;打max、min时&#xff0c;要用分支&#xff08;if语句&#xff09…

@PathVariable注解使用

PathVariable是spring3.0的一个新功能&#xff1a;接收请求路径中占位符的值 语法&#xff1a; PathVariable("xxx") 通过 PathVariable 可以将URL中占位符参数{xxx}绑定到处理器类的方法形参中PathVariable(“xxx“) RequestMapping(value”user/{id}/{name}”) 请…

【mysql】- 常用命令

DML - 操作表 SELECT * FROM stu;INSERT INTO stu ( id, NAME ) VALUES ( 1, 张三 );INSERT INTO stu ( id, NAME, sex, birthday, score, email, tel, STATUS ) VALUES( 2, 李四, 男, 1999-11-11, 88.888, lisiitcase.cn, 13812345678, 1 );update stu set sex 女 where nam…

JAVA 框架-Spring-AOP面向切面

AOP&#xff08;Aspect Orient Programming&#xff09;&#xff0c;我们一般称为面向方面&#xff08;切面&#xff09;编程&#xff0c;作为面向对象的一种补充&#xff0c;用于处理系统中分布于各个模块的横切关注点&#xff0c;比如事务管理、日志、缓存等等。AOP实现的关键…

互相关和卷积的关系

转载于:https://www.cnblogs.com/seisjun/p/10134021.html

Thymeleaf3语法详解

Thymeleaf是Spring boot推荐使用的模版引擎&#xff0c;除此之外常见的还有Freemarker和Jsp。Jsp应该是我们最早接触的模版引擎。而Freemarker工作中也很常见&#xff08;Freemarker教程&#xff09;。今天我们从三个方面学习Thymeleaf的语法&#xff1a;有常见的TH属性&#x…

【mysql】约束、外键约束、多对多关系

1、约束 DROP TABLE IF EXISTS emp;-- 员工表 CREATE TABLE emp (id INT PRIMARY KEY auto_increment, -- 员工id,主键且自增长ename VARCHAR(50) NOT NULL UNIQUE, -- 员工姓名,非空并且唯一joindate DATE NOT NULL, -- 入职日期,非空salary DOUBLE(7, 2) NULL, -- 工资,非空…

SSM+Netty项目结合思路

最近正忙于搬家&#xff0c;面试&#xff0c;整理团队开发计划等工作&#xff0c;所以没有什么时间登陆个人公众号&#xff0c;今天上线看到有粉丝想了解下Netty结合通用SSM框架的案例&#xff0c;由于公众号时间限制&#xff0c;我不能和此粉丝单独沟通&#xff0c;再此写一篇…

[6]Windows内核情景分析 --APC

APC&#xff1a;异步过程调用。这是一种常见的技术。前面进程启动的初始过程就是&#xff1a;主线程在内核构造好运行环境后&#xff0c;从KiThreadStartup开始运行&#xff0c;然后调用PspUserThreadStartup&#xff0c;在该线程的apc队列中插入一个APC&#xff1a;LdrInitial…

THYMELEAF 如何用TH:IF做条件判断

TestController 增加一个布尔值数据&#xff0c;并且放在model中便于视图上获取 package com.how2java.springboot.web; import java.util.ArrayList; import java.util.Date; import java.util.List;import org.springframework.stereotype.Controller; import org.springfr…

【mysql】多表查询、左外连接、内连接、练习题

多表查询 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FBdzXkoQ-1659581225088)(C:\Users\L00589~1\AppData\Local\Temp\1659337934641.png)] 左外连接&右外连接 -- 查询emp表所有数据和对应的部门信息 select * from emp left join dept o…

noi2018

day0 笔试没啥问题&#xff0c;基本都是100 day1 时间有点紧&#xff0c;念了2h题目&#xff0c;能写80848&#xff0c;第一题不会可持久化所以只能暴力。第二题感觉没第三个好做。第三题sa乱搞&#xff0c;随机串只hash长度小于20的。 最后几分钟才改过了所有小样例&#xff0…

Python自建collections模块

本篇将学习python的另一个内建模块collections,更多内容请参考:Python学习指南 collections是Python内建的一个集合模块&#xff0c;提供了许多有用的集合类。 namedtuple 我们知道tuple可以表示不变集合&#xff0c;例如&#xff0c;一个点的二维左边就可以表示成&#xff1a;…

Thymeleaf th:include、th:replace使用

最近做到页面数据展示分页的功能&#xff0c;由于每个模块都需要分页&#xff0c;所以每个页面都需要将分页的页码选择内容重复的写N遍&#xff0c;如下所示&#xff1a; 重复的代码带来的就是CtrlC&#xff0c;CtrlV ,于是了解了一下thymeleaf的fragment加载语法以及th:includ…

(OS X) OpenCV架构x86_64的未定义符号:错误(OpenCV Undefined symbols for architecture x86_64: error)...

原地址&#xff1a;http://www.it1352.com/474798.html 错误提示如下&#xff1a; Undefined symbols for architecture x86_64:"cv::_InputArray::_InputArray(cv::Mat const&)", referenced from:_main in test-41a30e.o"cv::namedWindow(std::__1::basic…

【算法】大根堆

const swap (arr, i, j) > {const tmp arr[i];arr[i] arr[j];arr[j] tmp; } const heapInsert (arr , i) > { // 插入大根堆的插入算法while(arr[i] > arr[Math.floor((i - 1) / 2]) {swap(arr, i, Math.floor((i - 1) / 2);i Math.floor((i - 1) / 2; } } cons…