首先考虑一个集合的最大优美值怎么求出

考虑新增一个数,假设我们现在的优美值已经达到了$V$,那么只需要一个$[1, V + 1]$的数就可以使$V$达到更大

为了保证能添加尽可能多的数进来,我们这么构造:

对集合$S$排序,从小到大选择,直到选到$\sum\limits_{i = 1}^{j}v[j] + 1 < v[j]$的$v[j]$,退出

为什么这么做正确呢?

如果不正确,只可能存在一个数$S$可以被大于一个数的和表示,并且满足$v[S] > V + 1$

其中$v[S]$表示构成$S$的所有$v$,$V$表示现在选出的和

由于整数的离散性,因此,一定有$v[S] \leqslant V + 1$,所以不可能不正确...

(很sb的证明....)

现在有两个集合了

只要进行这么一种操作$k$次就好了,记$W$表示从$S2$中选出的数的和,$S$表示目前$S1$中选出的数的和

1.找出使得$\sum\limits_{i = 1}^{k - 1} v[i] + W + 1 < v[k]$成立的最大的$k$,令$S  = \sum\limits_{i = 1}^{k - 1} v[i]$

2.再找出最大的且没有被选择的$j$使得$v[j] \leqslant W + S + 1$成立,之后选择$j$,$W += v[j]$,拿个栈维护即可

重复$k$次即可得出最后的结果

复杂度$O(Tm)$

注:那个㧟我快读的人拿rk3~~有猫病~~.....

注2:反正我还是rk1

  1. #include <cstdio>
  2. #include <cstring>
  3. #include <algorithm>
  4. using namespace std;
  5.  
  6. extern inline char gc() {
  7. static char RR[], *S = RR + , *T = RR + ;
  8. if(S == T) fread(RR, , , stdin), S = RR;
  9. return *S ++;
  10. }
  11. inline int read() {
  12. int p = , w = ; char c = gc();
  13. while(c > '' || c < '') { if(c == '-') w = -; c = gc(); }
  14. while(c >= '' && c <= '') p = p * + c - '', c = gc();
  15. return p * w;
  16. }
  17.  
  18. int wr[], rw;
  19. #define pc(x) *O ++ = x
  20. char WR[], *O = WR;
  21. inline void write(long long x) {
  22. if(!x) pc('');
  23. if(x < ) x = -x, pc('-');
  24. while(x) wr[++ rw] = x % , x /= ;
  25. while(rw) pc(wr[rw --] + ''); pc('\n');
  26. }
  27.  
  28. #define sid 1005
  29. #define ri register int
  30. #define ll long long
  31.  
  32. int n, T, tt;
  33. int num[sid], q[sid], S[sid][sid];
  34.  
  35. int main() {
  36. n = read();
  37. for(ri i = ; i <= n; i ++) {
  38. num[i] = read();
  39. for(ri j = ; j <= num[i]; j ++) S[i][j] = read();
  40. sort(S[i] + , S[i] + num[i] + );
  41. }
  42. T = read();
  43. for(ri i = ; i <= T; i ++) {
  44. int a = read(), b = read(), k = min(read(), num[b]);
  45. int *A = S[a], *B = S[b];
  46. ll ans = ; ri ia = , ib = ; tt = ;
  47. while(k) {
  48. while(A[ia] <= ans + && ia <= num[a]) ans += A[ia], ia ++;
  49. while(B[ib] <= ans + && ib <= num[b]) q[++ tt] = B[ib], ib ++;
  50. if(!tt) break; ans += q[tt --]; k --;
  51. }
  52. while(A[ia] <= ans + && ia <= num[a]) ans += A[ia], ia ++;
  53. write(ans);
  54. }
  55. fwrite(WR, , O - WR, stdout);
  56. return ;
  57. }

51nod1821 最优集合 贪心的更多相关文章

  1. 51NOD 1821 最优集合 栈

    1821 最优集合   一个集合S的优美值定义为:最大的x,满足对于任意i∈[1,x],都存在一个S的子集S',使得S'中元素之和为i. 给定n个集合,对于每一次询问,指定一个集合S1和一个集合S2, ...

  2. 51nod1821-最优集合【贪心】

    正题 题目链接:http://www.51nod.com/Challenge/Problem.html#problemId=1821 题目大意 \(n\)个可重集合,\(T\)次询问,询问将集合\(S ...

  3. CF 672C Recycling Bottles[最优次优 贪心]

    C. Recycling Bottles time limit per test 2 seconds memory limit per test 256 megabytes input standar ...

  4. 51NOD 1821 最优集合 [并查集]

    传送门 题意: 一个集合S的优美值定义为:最大的x,满足对于任意i∈[1,x],都存在一个S的子集S',使得S'中元素之和为i. 给定n个集合,对于每一次询问,指定一个集合S1和一个集合S2,以及一个 ...

  5. 51nod 1821 最优集合(思维+单调队列)

    题意:一个集合S的优美值定义为:最大的x,满足对于任意i∈[1,x],都存在一个S的子集S',使得S'中元素之和为i. 给定n个集合,对于每一次询问,指定一个集合S1和一个集合S2,以及一个数k,要求 ...

  6. 51Nod - 1821:最优集合 (求第一个不能被表示为多个数的和的数)(不错的动脑题)

    一个集合S的优美值定义为:最大的x,满足对于任意i∈1,x1,x,都存在一个S的子集S',使得S'中元素之和为i. 给定n个集合,对于每一次询问,指定一个集合S1和一个集合S2,以及一个数k,要求选择 ...

  7. 胡小兔的OI日志3 完结版

    胡小兔的 OI 日志 3 (2017.9.1 ~ 2017.10.11) 标签: 日记 查看最新 2017-09-02 51nod 1378 夹克老爷的愤怒 | 树形DP 夹克老爷逢三抽一之后,由于采 ...

  8. 【learning】加权拟阵与贪心

    首先.. 这篇东西的话算是一个关于拟阵部分知识的小总结,有些语言相对来说偏向便于理解方面,所以可能..有一些说法会不是那么严谨大概是这样 ​ 一些概念 线性无关:一组数据中没有一个量可以写成其余量的线 ...

  9. 1572: [Usaco2009 Open]工作安排Job[贪心]

    Description Farmer John 有太多的工作要做啊!!!!!!!!为了让农场高效运转,他必须靠他的工作赚钱,每项工作花一个单位时间. 他的工作日从0时刻开始,有1000000000个单 ...

随机推荐

  1. 【BZOJ】2631: tree LCT

    [题意]给定n个点的树,每个点初始权值为1,m次操作:1.x到y的点加值,2.断一条边并连一条边,保证仍是树,3.x到y的点乘值,4.x到y的点权值和取模.n,m<=10^5. [算法]Link ...

  2. koa通过get请求获取参数

    1.通过get方式请求获取参数的方式有两种 通过上下文获取 通过request获取 获得的格式有两种:query与querystring 注意:querystring为小写,驼峰格式会导致无法获取 2 ...

  3. 执行impdp时出现的各种问题

    1.不同的表空间,不同的用户,不同的表名 impdp ODS_YYJC_BUF_ZB/ODS_YYJC_BUF_ZB job_name=bs3 directory=EXPDMP exclude=OBJ ...

  4. 安全测试===CSRF攻击简介

    http://www.cnblogs.com/hyddd/archive/2009/04/09/1432744.html

  5. ASP.NET中的状态保持

    1.ASP.NET中的状态保持解决方案 2.常用的状态报保持方式 view state  ASP.Net的.aspx页面特有,页面级的,就是在页面上的一个隐藏域中保存客户端单独使用的数据的一种方式(b ...

  6. WebService初识

    Web service 是一种跨编程语言和跨操作系统平台的远程调用技术,即跨平台远程调用技术.也就是说,不管是J2EE架构,还是.net架构 只要按照规范就可以进行通信,实现数据交互等. 这里说的&q ...

  7. Error -27796: Failed to connect to server "ip地址": [10060] Connection timed out

    如果出现Error -27796: Failed to connect to server "ip地址": [10060] Connection timed out 这样的错误,如 ...

  8. BootStrap的栅格系统的基本写法(布局)

    代码如下: <!DOCTYPE html> <html> <head> <title>BootStrap的基础入门</title> < ...

  9. Templated Helper Methods(二)

      1.Label and Display Elements   2.Whole-Model Templated Helpers     3.Using Metadata to Control Edi ...

  10. oracle创建计划任务

    特别提示: oracle是执行完任务,才按照interval去计算下次执行时间!!! 为精确每个5分钟执行一个任务,必须自己计算时间. 如:trunc_minute(sysdate)+/ create ...