Description

有n个带标号的珠子,第i个珠子的价值为a[i]。现在你可以选择若干个珠子组成项链(也可以一个都不选),项链的价值为所有珠子的价值和。现在给所有可能的项链排序,先按权值从小到大排序,对于权值相同的,根据所用珠子集合的标号的字典序从小到大排序。请输出第k小的项链的价值,以及所用的珠子集合。

Input

第一行包含两个正整数n,k(1<=n<=1000000,1<=k<=min(2^n,1000000))。
第二行包含n个正整数,依次表示每个珠子的价值a[i](1<=a[i]<=10^9)。

Output

第一行输出第k小的项链的价值。
第二行按标号从小到大依次输出该项链里每个珠子的标号。

Sample Input

4 10
3 7 4 3

Sample Output

10
1 3 4

HINT

Source

鸣谢Claris

用堆来求k优解是一个很常用的方法了,我们先排序,堆中存入二元组(sum,i),表示和为sum,最大的元素的编号为i,

那么每次取出(sum,i),把(sum+a[i+1],i+1)和(sum-a[i]+a[i+1],i+1)丢入堆中即可;

然后我们考虑如何求出字典序,考虑用dfs来实现,假设dfs传的参为(x,sum),那么我们每次都是从(x+1,n)中最小的满足a[i]<=sum的i开始搜索,这样就不用枚举x+1-n了;

这样满足dfs求字典序的搜索顺序;因为我们只会搜索到k个,所以复杂度是对的;上面那个问题我们可以在线段树上进行查询;

线段树上维护区间最小值,然后在线段树上二分即可;

  1. //MADE BY QT666
  2. #include<iostream>
  3. #include<cstdio>
  4. #include<algorithm>
  5. #include<cstring>
  6. #include<queue>
  7. #define lson x<<1
  8. #define rson x<<1|1
  9. using namespace std;
  10. typedef long long ll;
  11. const int N=1000050;
  12. int n,k;
  13. ll ans[N],a[N],b[N],tr[N*4],Mn[N*4];
  14. struct data{
  15. ll sum;int j;
  16. };
  17. bool operator < (const data &a,const data &b){
  18. return a.sum>b.sum;
  19. }
  20. priority_queue<data> Q;
  21. int zhan[N],tot,tt,K;
  22. void build(int x,int l,int r){
  23. if(l==r) {tr[x]=l,Mn[x]=b[l];return;}
  24. int mid=(l+r)>>1;
  25. build(lson,l,mid);build(rson,mid+1,r);
  26. if(tr[lson]) tr[x]=tr[lson];
  27. if(tr[rson]) tr[x]=min(tr[x],tr[rson]);
  28. Mn[x]=min(Mn[lson],Mn[rson]);
  29. }
  30. int query(int x,int l,int r,int xl,int xr,ll v){
  31. if(l==r){
  32. if(Mn[x]<=v) return l;
  33. else return n+1;
  34. }
  35. if(xl<=l&&r<=xr){
  36. int mid=(l+r)>>1;
  37. if(Mn[x]>v) return n+1;
  38. else if(Mn[lson]<=v) return query(lson,l,mid,xl,mid,v);
  39. else return query(rson,mid+1,r,mid+1,xr,v);
  40. }
  41. int mid=(l+r)>>1;
  42. if(xr<=mid) return query(lson,l,mid,xl,xr,v);
  43. else if(xl>mid) return query(rson,mid+1,r,xl,xr,v);
  44. else return min(query(lson,l,mid,xl,mid,v),query(rson,mid+1,r,mid+1,xr,v));
  45. }
  46. void dfs(int x,ll sum){
  47. if(K>=tt) return;
  48. if(!sum){
  49. K++;
  50. if(K==tt) for(int i=1;i<=tot;i++) printf("%d ",zhan[i]);
  51. return;
  52. }
  53. if(x==n) return;
  54. for(int i=x+1;i<=n;i++){
  55. i=query(1,1,n,i,n,sum);
  56. if(i<=n){
  57. zhan[++tot]=i;dfs(i,sum-b[i]);tot--;
  58. }
  59. else return;
  60. }
  61. }
  62. int main(){
  63. scanf("%d%d",&n,&k);
  64. for(int i=1;i<=n;i++) scanf("%lld",&a[i]),b[i]=a[i];
  65. sort(a+1,a+1+n);Q.push((data){a[1],1});k--;
  66. for(int i=1;i<=k;i++){
  67. data x=Q.top();Q.pop();ans[i]=x.sum;
  68. if(x.j+1<=n) Q.push((data){x.sum+a[x.j+1],x.j+1});
  69. if(x.j+1<=n) Q.push((data){x.sum-a[x.j]+a[x.j+1],x.j+1});
  70. }
  71. while(ans[k]==ans[k-(tt+1)+1]) tt++;
  72. printf("%lld\n",ans[k]);build(1,1,n);
  73. dfs(0,ans[k]);
  74. return 0;
  75. }

bzoj 4345: [POI2016]Korale的更多相关文章

  1. 【BZOJ4345】[POI2016]Korale 堆(模拟搜索)

    [BZOJ4345][POI2016]Korale Description 有n个带标号的珠子,第i个珠子的价值为a[i].现在你可以选择若干个珠子组成项链(也可以一个都不选),项链的价值为所有珠子的 ...

  2. bzoj 4347 [POI2016]Nim z utrudnieniem DP

    4347: [POI2016]Nim z utrudnieniem Time Limit: 30 Sec  Memory Limit: 64 MBSubmit: 733  Solved: 281[Su ...

  3. BZOJ4345 : [POI2016]Korale

    只考虑第一问,将珠子按照价值从小到大排序,设排序后第$i$小的为$b[i]$,定义二元组$(x,y)$表示当前珠子的总价值为$x$,用的价值最大的珠子为$y$,用一个小根堆来维护所有状态.一开始往堆中 ...

  4. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  5. [bzoj4345][POI2016]Korale_堆_贪心_线段树_dfs

    bzoj4345 POI2016 Korale 题目链接:https://lydsy.com/JudgeOnline/problem.php?id=4345 数据范围:略. 题解: 由于$k$的范围问 ...

  6. BZOJ 2127: happiness [最小割]

    2127: happiness Time Limit: 51 Sec  Memory Limit: 259 MBSubmit: 1815  Solved: 878[Submit][Status][Di ...

  7. BZOJ 3275: Number

    3275: Number Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 874  Solved: 371[Submit][Status][Discus ...

  8. BZOJ 2879: [Noi2012]美食节

    2879: [Noi2012]美食节 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1834  Solved: 969[Submit][Status] ...

  9. bzoj 4610 Ceiling Functi

    bzoj 4610 Ceiling Functi Description bzoj上的描述有问题 给出\(n\)个长度为\(k\)的数列,将每个数列构成一个二叉搜索树,问有多少颗形态不同的树. Inp ...

随机推荐

  1. webpack之前端性能优化(史上最全,不断更新中。。。)

    最近在用webpack优化首屏加载性能,通过几种插件之后我们上线前后的速度快了一倍,在此就简单的分享下吧,先上个优化前后首屏渲染的对比图. 可以看到总下载时间从3800ms缩短到1600ms. 我们在 ...

  2. git使用(上)-----基本的方法

    git应该是一项必须要掌握的工具.先简述它和SVN的区别 SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以首先要从中央服务器哪里得到最新的版本,然后干活 ...

  3. 玩转html

    简介 CSS 是什么? CSS是Cascading Style Sheets的简称,中文称为层叠样式表. 作用 能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式,拥有对网页对象 ...

  4. Mysql--单表数据记录查询

    1.简单数据记录查询 1.1 简单数据查询 1.1.1 查询所有字段数据 例子:      1.1.2 "*"符号的使用 语法: 例子: 1.1.3 查询指定字段数据 例子:   ...

  5. 【java系列】java开发环境搭建

    描述 本篇文章主要讲解基于windows 10系统搭建java开发环境,主要内容包括如下: (1)安装资料准备 (2)安装过程讲解 (3)测试是否安装成功 (4)Hello Word测试 1   安装 ...

  6. php加密解密处理类

    [PHP]代码 <?php /*=========================================================== = 版权协议: = GPL (The GN ...

  7. linux下php7安装memcached、redis扩展

    linux下php7安装memcached.redis扩展 1.php7安装Memcached扩展 比如说我现在使用了最新的 Ubuntu 16.04,虽然内置了 PHP 7 源,但 memcache ...

  8. 匈牙利标记法定义ECMAScript变量前缀

    匈牙利标记法定义ECMAScript变量前缀 类型 前缀 示例 数组 a aArray 布尔型 b bMale 浮点型(数字)   f fTax 函数 fn fnSwap 整型(数字) i iAge ...

  9. Mac下CUDA开启及Tensorflow-gpu安装

    本文由@ray 出品,转载请注明出处.  文章链接:http://www.cnblogs.com/wolfray/p/8040694.html 在之前的文章中,笔者介绍了在Mac下安装Tensorfl ...

  10. Java VS .NET:Java与.NET的特点对比

    一.前言 为什么要写Java跟.NET对比? .NET出生之后就带着Java的影子.从模仿到创新,.NET平台也越来越成熟.他们不同的支持者也经常因为孰弱孰强的问题争论不休.但是本文并不是为了一分高下 ...