bzoj4345 POI2016 Korale

题目链接https://lydsy.com/JudgeOnline/problem.php?id=4345

数据范围:略。


题解

由于$k$的范围问题,我们很容易想到优先队列。

至于从每个状态怎么往下一个转移就是这个题的精髓。

我们先考虑第一问:

第一问没有字典序的限制,我们把所有的数按照从小到大排序。

堆里维护二元组$(Sum, id)$表示这种选取方式的和位$Sum$,最大下标为$id$。

它可以转移到$(Sum - a_{id} + a_{id+1}, id+1)$和$(Sum + a_{id + 1}, id + 1)$。

这一想是显然的,但是不咋好想...有点超级钢琴的味道。

下面我们考虑第二问:

第二问我们爆搜即可,想求出来当前下标(不排序)到最后一个数这个区间内,小于当前剩余和的最小下标的数是啥,然后暴力搜下去即可。

这个过程可以用线段树维护。

至于复杂度为什么是对的?因为我们每时每刻都保证了所有的枚举和都是小于第一问的值的,即使枚举到了第一问的值也在接受范围内。

言外之意我们枚举的每一个值,都是前$k-1$中的一个。

代码

#include <bits/stdc++.h>

#define ls p << 1 

#define rs p << 1 | 1 

#define N 1000010 

using namespace std;

typedef long long ll;

char *p1, *p2, buf[100000];

#define nc() (p1 == p2 && (p2 = (p1 = buf) + fread(buf, 1, 100000, stdin), p1 == p2) ? EOF : *p1 ++ )

int rd() {
int x = 0;
char c = nc();
while (c < 48) {
c = nc();
}
while (c > 47) {
x = (((x << 2) + x) << 1) + (c ^ 48), c = nc();
}
return x;
} priority_queue <pair<ll, int> > q; int a[N], b[N], Same, mn[N << 2]; ll ans[N]; inline void pushup(int p) {
mn[p] = min(mn[ls], mn[rs]);
} void build(int l, int r, int p) {
if (l == r) {
mn[p] = b[l];
return;
}
int mid = (l + r) >> 1;
build(l, mid, ls), build(mid + 1, r, rs);
pushup(p);
} int query(int x, ll y, int l, int r, int p) {
if (x <= l) {
if (mn[p] > y) {
return 0;
}
if (l == r) {
return l;
}
}
int mid = (l + r) >> 1;
if (x <= mid) {
int mdl = query(x, y, l, mid, ls);
if (mdl) {
return mdl;
}
}
return query(x, y, mid + 1, r, rs);
} int top, st[N], n, k; void dfs(int p, ll re) {
if (!Same) {
return;
}
if (!re) {
Same -- ;
if (!Same) {
for (int i = 1; i <= top; i ++ ) {
printf("%d ", st[i]);
}
puts("");
}
return;
}
for (int i = p + 1; i <= n; i ++ ) {
i = query(i, re, 1, n, 1);
if (i) {
st[ ++ top] = i;
dfs(i, re - b[i]);
top -- ;
}
else {
break;
}
}
} int main() {
n = rd(), k = rd() - 1;
for (int i = 1; i <= n; i ++ ) {
a[i] = b[i] = rd();
}
sort(a + 1, a + n + 1);
q.push(make_pair(-a[1], 1));
for (int i = 1; i <= k; i ++ ) {
ans[i] = -q.top().first;
int x = q.top().second;
q.pop();
if (x < n) {
q.push(make_pair(-(ans[i] - a[x] + a[x + 1]), x + 1));
q.push(make_pair(-(ans[i] + a[x + 1]), x + 1));
}
}
// for (int i = 1; i <= k; i ++ ) {
// printf("%lld ", ans[i]);
// }
// puts("");
cout << ans[k] << endl ;
for (int i = k; i; i -- ) {
if (ans[i] != ans[k]) {
break;
}
Same ++ ;
}
// cout << Same << endl ;
build(1, n, 1);
dfs(0, ans[k]);
return 0;
}

[bzoj4345][POI2016]Korale_堆_贪心_线段树_dfs的更多相关文章

  1. BZOJ_2161_布娃娃_权值线段树

    BZOJ_2161_布娃娃_权值线段树 Description 小时候的雨荨非常听话,是父母眼中的好孩子.在学校是老师的左右手,同学的好榜样.后来她成为艾利斯顿第二 代考神,这和小时候培养的良好素质是 ...

  2. BZOJ_3685_普通van Emde Boas树_权值线段树

    BZOJ_3685_普通van Emde Boas树_权值线段树 Description 设计数据结构支持: 1 x  若x不存在,插入x 2 x  若x存在,删除x 3    输出当前最小值,若不存 ...

  3. B20J_2733_[HNOI2012]永无乡_权值线段树合并

    B20J_2733_[HNOI2012]永无乡_权值线段树合并 Description:n座岛,编号从1到n,每座岛都有自己的独一无二的重要度,按照重要度可以将这n座岛排名,名次用1到 n来表示.某些 ...

  4. BZOJ_1503_[NOI2004]郁闷的出纳员_权值线段树

    BZOJ_1503_[NOI2004]郁闷的出纳员_权值线段树 Description OIER公司是一家大型专业化软件公司,有着数以万计的员工.作为一名出纳员,我的任务之一便是统计每位员工的 工资. ...

  5. BZOJ_1012_[JSOI2008]_最大数maxnumber_(线段树/树状数组+RMQ)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1012 两种操作: 1.求序列末尾n个数中的最大值. 2.在序列末尾插入一个数. 分析 线段树求 ...

  6. [bzoj2733][HNOI2012]永无乡_权值线段树_线段树合并

    永无乡 bzoj-2733 HNOI-2012 题目大意:题目链接. 注释:略. 想法: 它的查询操作非常友善,就是一个联通块内的$k$小值. 故此我们可以考虑每个联通块建一棵权值线段树. 这样的话每 ...

  7. [jdoj1258]野生动物园(change by panxf)_权值线段树_组合数

    人品计算 题目大意:n个数的a序列,m组询问.每次询问给出T,A,B,K.求在a序列的[A,B]的位置之内的K小值P,的$C_{T}^{P \% T} \% 10111$. 注释:每组询问保证区间只相 ...

  8. 3065: 带插入区间K小值_树套树_替罪羊树_权值线段树

    经过周六一天,周一3个小时的晚自习,周二2个小时的疯狂debug,终于凭借自己切掉了这道树套树题. Code: #include <cstdio> #include <algorit ...

  9. 【Luogu1973】仓配置(贪心,线段树)

    [Luogu1973]仓配置 题面 直接找洛谷把... 题解 很明显的贪心吧 按照线段的右端点为第一关键字,左端点第二关键字排序 然后线段树维护区间最小就可以啦 #include<iostrea ...

随机推荐

  1. Redis恢复数据

    对于单点或者集群,都可以用 cat data.txt | redis-cli --pipe方式进行冷恢复. 对于大数据量会很慢,但不会出错.

  2. vue项目开发中遇到的几个问题

    1.使用elment或者mintUI库时,需要全局引入ui库的css文件:然后在修改自己样式时,需要将自己的css文件引入到main.js中才会生效,全局引用2.使用v-html展示dom字符串时,相 ...

  3. web 安全登录算法

    摘自:http://hi.baidu.com/weiqi228/blog/item/922e961bbcc2c0188618bfb5.html 对于 Web 应用程序,安全登录是很重要的.但是目前大多 ...

  4. Tuxedo 介绍

    快速阅读 介绍Tuxedo,以及webLogic两个中间件,都是oracle旗下的产品 ,现在各银行系统用的最多.因为有部分项目涉及,所以有必须弄清楚,明白 . 什么是Tuxedo 官方介绍:http ...

  5. 2018-2019-2 网络对抗技术 20165212 Exp 8 Web基础

    2018-2019-2 网络对抗技术 20165212 Exp 8 Web基础 原理与实践说明 1.实践内容概述 1.Web前端HTML 能正常安装.启停Apache.理解HTML,理解表单,理解GE ...

  6. make 实例 一 3463

    ######################################################################### # # Makefile used for buil ...

  7. python自动化登录获取图片登录验证码

    主要记录一下:图片验证码1.获取登录界面的图片2.获取验证码位置3.在登录页面截取验证码保存4.调用百度api识别(目前准确率较高的识别图片api)本次登录的系统页面,可以看到图片验证码的位置登录页面 ...

  8. OpenJudge 计算概论1007:点评赛车

    总时间限制: 1000ms 内存限制: 65536kB描述4名专家对4款赛车进行评论1)A说:2号赛车是最好的:2)B说:4号赛车是最好的:3)C说:3号赛车不是最好的:4)D说: B说错了.事实上只 ...

  9. (转)设置了RemoveIPC=yes 的RHEL7.2 会crash掉Oracle asm 实例和Oracle database实例

    设置了RemoveIPC=yes 的RHEL7.2  会crash掉Oracle asm 实例和Oracle database实例,该问题也会在使用Shared Memory Segment (SHM ...

  10. 使用AWS Lambda,API Gateway和S3 Storage快速调整图片大小

    https://www.obytes.com/blog/2019/image-resizing-on-the-fly-with-aws-lambda,-api-gateway,-and-s3-stor ...