题目描述

N柱砖,希望有连续K柱的高度是一样的. 你可以选择以下两个动作 1:从某柱砖的顶端拿一块砖出来,丢掉不要了. 2:从仓库中拿出一块砖,放到另一柱.仓库无限大. 现在希望用最小次数的动作完成任务.你还要求输出结束状态时,每柱砖的高度。

Solution

这题相当于我们滑动一个大小为k的窗口,我们可以任意改动每摞砖的高度,那么最优高度为多少呢,很显然是中位数。

所以这题变成了一道大水题,维护一个数据结构,支持插入,删除,查K大。

Code

#include<iostream>
#include<cstdio>
#include<algorithm>
#define N 100004
using namespace std;
int n,a[N],num[N<<],k,top,jue;
long long tr[N<<],ans=0x7f7f7f7f,b[N],ansn;
long long q(int cnt,int l,int r,int L,int R){
if(L>R)return ;
if(l>=L&&r<=R)return tr[cnt];
int mid=(l+r)>>;
long long ans=;
if(mid>=L)ans+=q(cnt<<,l,mid,L,R);
if(mid<R)ans+=q(cnt<<|,mid+,r,L,R);
return ans;
}
int qsum(int cnt,int l,int r,int L,int R){
if(L>R)return ;
if(l>=L&&r<=R)return num[cnt];
int mid=(l+r)>>;
int ans=;
if(mid>=L)ans+=qsum(cnt<<,l,mid,L,R);
if(mid<R)ans+=qsum(cnt<<|,mid+,r,L,R);
return ans;
}
void add(int cnt,int l,int r,int x,int tag){
if(l==r){tr[cnt]+=b[x]*tag;num[cnt]+=tag;return;}
int mid=(l+r)>>;
if(mid>=x)add(cnt<<,l,mid,x,tag);
else add(cnt<<|,mid+,r,x,tag);
tr[cnt]=tr[cnt<<]+tr[cnt<<|];
num[cnt]=num[cnt<<]+num[cnt<<|];
}
int find(int cnt,int l,int r,int k){
if(l==r)return l;
int mid=(l+r)>>;
if(num[cnt<<]>=k)return find(cnt<<,l,mid,k);
else return find(cnt<<|,mid+,r,k-num[cnt<<]);
}
int main(){
scanf("%d%d",&n,&k);
for(int i=;i<=n;++i)scanf("%d",&a[i]),b[i]=a[i];
sort(b+,b+n+);
top=unique(b+,b+n+)-b-;
for(int i=;i<=n;++i)a[i]=lower_bound(b+,b+top+,a[i])-b;
for(int i=;i<=k;++i)add(,,top,a[i],);
ans=2e18;
long long sum=(k+)/;
for(int i=k;i<=n;++i){
int x=find(,,top,sum);
long long aa=b[x]*qsum(,,top,,x-)-q(,,top,,x-)+q(,,top,x+,top)-b[x]*qsum(,,top,x+,top);
if(aa<ans){
ans=aa;
jue=i;
ansn=b[x];
}
add(,,top,a[i+],);add(,,top,a[i-k+],-);
}
printf("%lld\n",ans);
for(int i=;i<jue-k+;++i)printf("%d\n",b[a[i]]);
for(int i=jue-k+;i<=jue;++i)printf("%d\n",ansn);
for(int i=jue+;i<=n;++i)printf("%d\n",b[a[i]]);
return ;
}

[POI2008]KLO-Building blocks的更多相关文章

  1. Intel® Threading Building Blocks (Intel® TBB) Developer Guide 中文 Parallelizing Data Flow and Dependence Graphs并行化data flow和依赖图

    https://www.threadingbuildingblocks.org/docs/help/index.htm Parallelizing Data Flow and Dependency G ...

  2. bc.34.B.Building Blocks(贪心)

    Building Blocks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  3. DTD - XML Building Blocks

    The main building blocks of both XML and HTML documents are elements. The Building Blocks of XML Doc ...

  4. 企业架构研究总结(35)——TOGAF架构内容框架之构建块(Building Blocks)

    之前忙于搬家移居,无暇顾及博客,今天终于得闲继续我的“政治课”了,希望之后至少能够补完TOGAF方面的内容.从前面文章可以看出,笔者并无太多能力和机会对TOGAF进行理论和实际的联系,仅可对标准的文本 ...

  5. TOGAF架构内容框架之构建块(Building Blocks)

    TOGAF架构内容框架之构建块(Building Blocks) 之前忙于搬家移居,无暇顾及博客,今天终于得闲继续我的“政治课”了,希望之后至少能够补完TOGAF方面的内容.从前面文章可以看出,笔者并 ...

  6. HDU—— 5159 Building Blocks

    Problem Description After enjoying the movie,LeLe went home alone. LeLe decided to build blocks. LeL ...

  7. [翻译]Review——How JavaScript works:The building blocks of Web Workers

    原文地址:https://blog.sessionstack.com/how-javascript-works-the-building-blocks-of-web-workers-5-cases-w ...

  8. 四、Implementation: The Building Blocks 实现:构件

    四.Implementation: The Building Blocks 实现:构件 This is the essential part of this guide. We will introd ...

  9. 2.3 Core Building Blocks 核心构件

    Core Building Blocks 核心构件 DDD mostly focuses on the Domain & Application Layers and ignores the ...

  10. 解题:POI2008 Building blocks

    题面 显然我们需要考虑每一个区间,而这个问题显然我们都会做,这不就是这道题么,也就是说假如中位数是$mid$,区间和是$sum$,那么代价就是$\sum\limits_{i=l}^r |mid-num ...

随机推荐

  1. js判断是否是微信浏览器以及重定向

    async created () {//这个是判断是否是微信浏览器, let ua = navigator.userAgent.toLowerCase() if (ua.match(/MicroMes ...

  2. Oracle 修改数据库表数据提交之后进行回滚

    --查看历史数据 select * from test1 as of timestamp to_timestamp('2018-12-23 14:41:00', 'yyyy-mm-dd hh24:mi ...

  3. DTW动态时间规整

    参考: https://blog.csdn.net/raym0ndkwan/article/details/45614813

  4. python之路--MySQL多表查询

    一 介绍 我们在写项目的时候一般都会建一个数据库,数据库里面会存很多的表,不可能把所有的数据都放在一张表里,因为分表来存数据节省空间,数据的组织结构更清晰,解耦和程度更高,但是这些表本质上还不是一个整 ...

  5. python之路--关于线程的一些方法

    一 . 线程的两种创建方式 from threading import Thread # 第一种创建方式 def f1(n): print('%s号线程任务'%n) def f2(n): print( ...

  6. vue起步和模板語法

    vue構造器里有哪些內容: var a=new Vue({}) 模板語法: 文本插值: html: html的屬性里的值應該使用v-bind: 表達式: 指令; 參數:v-bind,v-on 雙向用戶 ...

  7. Redis 禁用FLUSHALL FLUSHDB KEYS 命令

      (error) ERR unknown command 'keys'问题解决(error) ERR unknown command 'FLUSHDB' 问题解决 背景 FLUSHALL FLUSH ...

  8. 扩展运算符(spread)是三个点(…)

    扩展运算符(spread)是三个点(…),将一个数组||类数组||字符串转为用逗号分隔的序列. js中用来对数组进行操作,把数组里面的东西统统拿出来 一.展开数组 //展开数组 let a = [1, ...

  9. vue 使用技巧总结 18.11

    前言: 在大概学完 vue 整体框架后,有幸接触到花裤衩大神写的 vue-elementUI-admin 模板框架,把这个模板框架当作 demo,跟着 code 一遍,最大的收获是在以逻辑简单的模板熟 ...

  10. How to reset macOS Icon Cache

    find . -name cuthead.txt find /private/var/folders/ -name 'com.apple.dock.iconcache' -delete find /p ...