题目描述

输入

输出

样例输入

3 4

1 3 4

样例输出

8 7 4 4

数据范围

样例解释

解法

二分做法

考虑到可以二分第k大的值mid,如果比mid大的区间和数小于或等于mid,那么mid就合法。

找一个合法的最小mid就是我们要找的mid。


询问有多少个区间大于或等于mid可以使用dfs,从[1,n]开始;

设当前dfs到[l,r],如果当前区间合法,就可以推到[l,r-1]和[l+1,r]。

否则直接退出。


时间复杂度为O(log(maxa)∗k)。

堆做法

先把所有[1,i]加入堆中。

操作k次:

1.取出堆中最大的一个区间并输出。

2.设这个区间为[l,r],如果l<r,那么把[l+1,r]加入堆中。


正确性:

由于可以[l,r]一定大于[l+1,r],所以一开始堆外元素一定没有比任何堆中元素更大的。


时间复杂度为O(log(maxa)∗k)。

代码

#include<iostream>
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<algorithm>
#define ll long long
#define ln(x,y) ll(log(x)/log(y))
#define sqr(x) ((x)*(x))
using namespace std;
const char* fin="ksum.in";
const char* fout="ksum.out";
const ll inf=0x7fffffff;
const ll maxn=100007;
ll n,m,i,j,k,l,r,mid,mmid,sum=0,num,head,tail;
ll a[maxn],c[maxn*2],b[maxn*2][2];
bool ansflag;
void add(ll l,ll r){
b[++tail][0]=l;
b[tail][1]=r;
}
void dfs(ll l,ll r,ll limit){
head=0;
tail=0;
add(l,r);
while (head++<tail){
ll l=b[head][0],r=b[head][1];
if (a[r]-a[l-1]>=limit){
num++;
if (ansflag) c[++c[0]]=a[r]-a[l-1];
}else continue;
if (!ansflag && num>m) continue;
if (l==r) continue;
if (r==n) add(l+1,r);
if (!ansflag && num>m) continue;
add(l,r-1);
}
}
bool judge(ll x){
num=0;
dfs(1,n,x);
if (num>=m) return true;
else return false;
}
int main(){
freopen(fin,"r",stdin);
freopen(fout,"w",stdout);
scanf("%d%d",&n,&m);
if (m==0) return 0;
for (i=1;i<=n;i++){
scanf("%d",&a[i]);
a[i]+=a[i-1];
}
l=1;
r=a[n];
while (l<r-1){
mid=(l+r)/2;
if (judge(mid)) l=mid;
else r=mid;
}
if (!judge(l)) l=r;
ansflag=true,num=0,dfs(1,n,l);
sort(c+1,c+c[0]+1);
for (i=c[0];i>c[0]-m;i--) printf("%lld ",c[i]);
return 0;
}

启发

把问题想复杂了,不需要二分甚至三分。

好好利用[l,r]>max([l+1,r],[l,r−1])这个性质即可解题。

【JZOJ4815】【NOIP2016提高A组五校联考4】ksum的更多相关文章

  1. NOIP2016提高A组五校联考4总结

    坑爹的第一题,我居然想了足足3个小时,而且还不确定是否正确. 于是,我就在这种情况下心惊胆跳的打了,好在ac了,否则就爆零了. 第二题,树形dp,本来差点就想到了正解,结果时间不够,没打完. 第三题, ...

  2. 【NOIP2016提高A组五校联考4】square

    题目 分析 首先,设\(f_{i,j}\)表示最大的以(i,j)为左下角的正方形的边长. 转移显然,\(f_{i,j}=\max(f_{i-1,j},f_{i,j-1},f_{i-1,j-1})+1\ ...

  3. 【NOIP2016提高A组五校联考4】label

    题目 题目 20%算法 设\(f_{i,j}\)表示第i个节点选了j这个权值的方案数. 显然转移方程为,\[f_{i,j}=\Pi_{v=son(i)}(\sum_{k=1}^{j-k}f_{v,k} ...

  4. 【NOIP2016提高A组五校联考4】ksum

    题目 分析 发现,当子段[l,r]被取了出来,那么[l-1,r].[l,r+1]一定也被取了出来. 那么,首先将[1,n]放入大顶堆,每次将堆顶的子段[l,r]取出来,因为它是堆顶,所以一定是最大的子 ...

  5. NOIP2016提高A组五校联考3总结

    第一题,本来一开始就想到了数位dp,结果脑残地打了十几个转移方程,总是调试不出来,一气之下放弃了. 调第一题几乎调了整节比赛,第二第三都没它. 第二题连边找联通块. 第三题题解都打了三页,看都不想看. ...

  6. 【NOIP2016提高A组五校联考2】tree

    题目 给一棵n 个结点的有根树,结点由1 到n 标号,根结点的标号为1.每个结点上有一个物品,第i 个结点上的物品价值为vi. 你需要从所有结点中选出若干个结点,使得对于任意一个被选中的结点,其到根的 ...

  7. 【NOIP2016提高A组五校联考2】running

    题目 小胡同学是个热爱运动的好孩子. 每天晚上,小胡都会去操场上跑步,学校的操场可以看成一个由n个格子排成的一个环形,格子按照顺时针顺序从0 到n- 1 标号. 小胡观察到有m 个同学在跑步,最开始每 ...

  8. 【NOIP2016提高A组五校联考2】string

    题目 给出一个长度为n, 由小写英文字母组成的字符串S, 求在所有由小写英文字母组成且长度为n 且恰好有k 位与S 不同的字符串中,给定字符串T 按照字典序排在第几位. 由于答案可能很大,模10^9 ...

  9. NOIP2016提高A组五校联考2总结

    第一题用组合数各种乱搞,其恶心程度不一般.搞了很久才调对,比赛上出了一点bug,只拿了30分. 第二题我乱搞得出个错误的结论,本来自信满满60分,结果爆零了. 第三题,树形dp,在一开始的时候想到了, ...

随机推荐

  1. Ionic 图片预览ion-slide-box,ion-slide,ion-scroll实现

    1.index.html 代码 <body ng-app="starter"> <ion-pane> <ion-header-bar class=&q ...

  2. 浏览器标准模式与怪异模式-CSS1Compat and BackCompat

    由于历史的原因,各个浏览器在对页面的渲染上存在差异,甚至同一浏览器在不同版本中,对页面的渲染也不同.在W3C标准出台以前,浏览器在对页面的渲染上没有统一规范,产生了差异(Quirks mode或者称为 ...

  3. 做网站-mysql表字段设计

    https://mp.weixin.qq.com/s/HhdbmQqKmiw9IVnnL0Zyag VARCHAR与CHAR如何选择 使用VARCHAR理由 字段不经常更新 字段比较长,且长度不均(比 ...

  4. 【MFC 】关于对话框中的OnVScroll() 和 OnHScroll

    原文地址:[MFC 中]关于对话框中的OnVScroll() 和 OnHScroll()函数作者:Winters     对话框中的滑块,微调控件都会向OnVScroll() 和OnHScroll() ...

  5. mongodb+nodejs 增删查的demo

    1.启动数据库 启动完成后显示 端口号是27017 2.创建数据库 创建一个名为mydb的数据库   3.先查询一下当然的用户,再新增一个 4.创建数据表,查询所有的表 db.createCollec ...

  6. Redis源码解析:13Redis中的事件驱动机制

    Redis中,处理网络IO时,采用的是事件驱动机制.但它没有使用libevent或者libev这样的库,而是自己实现了一个非常简单明了的事件驱动库ae_event,主要代码仅仅400行左右. 没有选择 ...

  7. 在Ubuntu Server 14.04上源码安装Odoo 9.0

    1. 更新Ubuntu服务器软件源 sudo apt-get update #更新软件源 sudo apt-get dist-upgrade #更新软件包,自动查找依赖关系 sudo shutdown ...

  8. 修改代码150万行!与 Blink 合并后的 Apache Flink 1.9.0 究竟有哪些重大变更?

    8月22日,Apache Flink 1.9.0 正式发布,早在今年1月,阿里便宣布将内部过去几年打磨的大数据处理引擎Blink进行开源并向 Apache Flink 贡献代码.当前 Flink 1. ...

  9. Jdbc封装和对CURD的封装

    1.查询emp表中的所有记录为例 2.测试类 public Emp getByNameAndEmail(String name, String email){ String sql = "s ...

  10. 组合数学起步-排队[HNOI2012][BZOJ2729]

    <题面> 这个题十分基础 写这个博客给自己看的呵呵 遇到这个题,一看就是组合数学, so,开始推公式, 刚开始想的是,先排男生,再排女生,最后排老师 推了一会,呃呃呃,情况复杂,考虑的好像 ...