题目描述

奶牛们计划着去海滩上享受日光浴。为了避免皮肤被阳光灼伤,所有C(1 <= C <= 2500)头奶牛必须在出门之前在身上抹防晒霜。第i头奶牛适合的最小和最 大的SPF值分别为minSPF_i和maxSPF_i(1 <= minSPF_i <= 1,000; minSPF_i <= maxSPF_i <= 1,000)。如果某头奶牛涂的防晒霜的SPF值过小,那么阳光仍然能 把她的皮肤灼伤;如果防晒霜的SPF值过大,则会使日光浴与躺在屋里睡觉变得 几乎没有差别。为此,奶牛们准备了一大篮子防晒霜,一共L(1 <= L <= 2500)瓶。第i瓶 防晒霜的SPF值为SPF_i(1 <= SPF_i <= 1,000)。瓶子的大小也不一定相同,第i 瓶防晒霜可供cover_i头奶牛使用。当然,每头奶牛只能涂某一个瓶子里的防晒霜 ,而不能把若干个瓶里的混合着用。 请你计算一下,如果使用奶牛们准备的防晒霜,最多有多少奶牛能在不被灼 伤的前提下,享受到日光浴的效果?

输入

* 第1行: 2个用空格隔开的整数:C和L

* 第2..C+1行: 第i+1行给出了适合第i头奶牛的SPF值的范围:minSPF_i以及 maxSPF_i * 第C+2..C+L+1行: 第i+C+1行为了第i瓶防晒霜的参数:SPF_i和cover_i,两个 数间用空格隔开。

输出

* 第1行: 输出1个整数,表示最多有多少头奶牛能享受到日光浴

样例输入

3 2
3 10
2 5
1 5
6 2
4 1

样例输出

2


题解

贪心+Treap

首先有贪心法则:将牛按照最大范围从小到大排序,依次寻找能够选择的spf最小的防晒霜。

简单地证明一下:存在较小的和较大的防晒霜。当较大的不超后面的牛范围时,如果较小的能被后面的牛所选,那么较大的一定能被后面的牛所选,反过来不一定成立。所以尽量留下较大的,即尽量选择较小的。当较大的超后面的牛的范围时,也一定超前面的牛的范围,无论如何都无法选择它,不会使答案变小。

于是按照贪心法则,使用Treap来求后继即可。

  1. #include <cstdio>
  2. #include <cstdlib>
  3. #include <algorithm>
  4. using namespace std;
  5. struct data
  6. {
  7. int ml , mr;
  8. }a[2501];
  9. int num[2501] , cnt[2501] , rnd[2501] , l[2501] , r[2501] , root , tot , tmp;
  10. bool cmp(data a , data b)
  11. {
  12. return a.mr < b.mr;
  13. }
  14. void zig(int &k)
  15. {
  16. int t = l[k];
  17. l[k] = r[t];
  18. r[t] = k;
  19. k = t;
  20. }
  21. void zag(int &k)
  22. {
  23. int t = r[k];
  24. r[k] = l[t];
  25. l[t] = k;
  26. k = t;
  27. }
  28. void ins(int &k , int x , int c)
  29. {
  30. if(!k)
  31. {
  32. k = ++tot;
  33. num[k] = x;
  34. cnt[k] = c;
  35. rnd[k] = rand();
  36. return;
  37. }
  38. if(x == num[k])
  39. cnt[k] += c;
  40. else if(x < num[k])
  41. {
  42. ins(l[k] , x , c);
  43. if(rnd[l[k]] < rnd[k])
  44. zig(k);
  45. }
  46. else
  47. {
  48. ins(r[k] , x , c);
  49. if(rnd[r[k]] < rnd[k])
  50. zag(k);
  51. }
  52. }
  53. void del(int &k , int x)
  54. {
  55. if(x == num[k])
  56. {
  57. if(cnt[k] > 1)
  58. cnt[k] -- ;
  59. else if(l[k] * r[k] == 0)
  60. k = l[k] + r[k];
  61. else if(rnd[l[k]] < rnd[r[k]])
  62. zig(k) , del(k , x);
  63. else
  64. zag(k) , del(k , x);
  65. }
  66. else if(x < num[k])
  67. del(l[k] , x);
  68. else
  69. del(r[k] , x);
  70. }
  71. void sub(int k , int x)
  72. {
  73. if(!k) return;
  74. if(x < num[k])
  75. tmp = num[k] , sub(l[k] , x);
  76. else
  77. sub(r[k] , x);
  78. }
  79. int main()
  80. {
  81. int n , m , i , x , y , ans = 0;
  82. scanf("%d%d" , &n , &m);
  83. for(i = 0 ; i < n ; i ++ )
  84. scanf("%d%d" , &a[i].ml , &a[i].mr);
  85. sort(a , a + n , cmp);
  86. while(m -- )
  87. {
  88. scanf("%d%d" , &x , &y);
  89. ins(root , x , y);
  90. }
  91. for(i = 0 ; i < n ; i ++ )
  92. {
  93. tmp = 0;
  94. sub(root , a[i].ml - 1);
  95. if(tmp && tmp <= a[i].mr)
  96. ans ++ , del(root , tmp);
  97. }
  98. printf("%d\n" , ans);
  99. return 0;
  100. }

【bzoj1707】[Usaco2007 Nov]tanning分配防晒霜 贪心+Treap的更多相关文章

  1. [BZOJ1707] [Usaco2007 Nov] tanning分配防晒霜 (贪心)

    Description 奶牛们计划着去海滩上享受日光浴.为了避免皮肤被阳光灼伤,所有C(1 <= C <= 2500)头奶牛必须在出门之前在身上抹防晒霜.第i头奶牛适合的最小和最 大的SP ...

  2. BZOJ1707 : [Usaco2007 Nov]tanning分配防晒霜

    S向每头奶牛连边,容量1 每个防晒霜向T连边,容量cover 每头奶牛向SPF在自己范围内的防晒霜连边,容量inf 用线段树优化建图跑最大流即可. #include<cstdio> con ...

  3. 【BZOJ】1707: [Usaco2007 Nov]tanning分配防晒霜

    [算法]贪心扫描线(+堆) [题意]给定n头牛有区间[a,b],m个防晒霜值为ai,每个可以使用bi次,每次可以使包含它的区间涂到防晒霜,问最多被涂牛数. [题解] 参考:[bzoj1707]: [U ...

  4. 1707: [Usaco2007 Nov]tanning分配防晒霜

    1707: [Usaco2007 Nov]tanning分配防晒霜 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 548  Solved: 262[Sub ...

  5. BZOJ1707:[Usaco2007 Nov]tanning分配防晒霜

    我对贪心的理解:https://www.cnblogs.com/AKMer/p/9776293.html 题目传送门:https://www.lydsy.com/JudgeOnline/problem ...

  6. bzoj 1707: [Usaco2007 Nov]tanning分配防晒霜【贪心||最大流(?)】

    洛谷上能过的最大流bzoj上T了--但是贪心做法明明在洛谷上比最大流要慢啊--如果是最大流的话就是裸题了吧 说一下贪心,就按照防晒霜排序,然后对每一个防晒霜选一头可以使用的且r最小的牛 就,没了. 贪 ...

  7. BZOJ 1707 [Usaco2007 Nov]tanning分配防晒霜(扫描线+贪心+优先队列)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=1707 [题目大意] 每个奶牛各自能够忍受的阳光强度有一个最小值和一个最大值 防晒霜的作 ...

  8. BZOJ 1707: [Usaco2007 Nov]tanning分配防晒霜

    Description 奶牛们计划着去海滩上享受日光浴.为了避免皮肤被阳光灼伤,所有C(1 <= C <= 2500)头奶牛必须在出门之前在身上抹防晒霜.第i头奶牛适合的最小和最 大的SP ...

  9. BZOJ——T 1707: [Usaco2007 Nov]tanning分配防晒霜

    http://www.lydsy.com/JudgeOnline/problem.php?id=1707 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 8 ...

随机推荐

  1. 20145234黄斐《Java程序设计》第一周学习总结

    教材学习内容总结 1.java是SUN公司推出的面相网络的编程语言,当时取名Oak,后改名Java. 2.Java三大平台分别为:Java SE.Java EE与Java ME. 3.Java不仅是程 ...

  2. BZOJ1800_fly飞行棋_KEY

    题目传送门 看数据范围,N<=20! 你没看错,搜索都能过. O(N^2)的做法,就是先求出有几对点之间的距离为圆周长的一半. 然后求C(N,2)即可. code: /************* ...

  3. 北京Uber优步司机奖励政策(1月18日)

    滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...

  4. Python3 之选课系统

    项目介绍:项目名称:(oldboy选课系统)项目功能: 分为 学员视角, 老师视角 , 管理员视角 学员视角{ (注册 登录 个人中心 选课 学习 上课) 登录 就是登录 注册: 填写 资料 信息 完 ...

  5. netty之心跳机制

    1.心跳机制,在netty3和netty5上面都有.但是写法有些不一样. 2.心跳机制在服务端和客户端的作用也是不一样的.对于服务端来说:就是定时清除那些因为某种原因在一定时间段内没有做指定操作的客户 ...

  6. eclipse导入jmeter3.1源码并运行

    jmeter3.1源码地址:https://archive.apache.org/dist/jmeter/source/ 1.打开eclipse,新建一个java project的项目,并点击next ...

  7. SSM-最新pom.xml

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  8. C 基本运算

    一 算术运算 C语言一共有34种运算符 包括了常见的加减乘除运算 1. 加法运算+ 除开能做加法运算 还能表示正号: +5, +90 2. 减法运算- 除开能做减法运算 还能表示符号: -10, -2 ...

  9. 【Linux 运维】linux系统查看版本信息

    查看linux系统版本信息: [root@kvm-host~]# cat /proc/version       (Linux查看当前操作系统版本信息)Linux version 3.10.0-514 ...

  10. MyBatis 注解配置及动态SQL

      一.注解配置 目前MyBatis支持注解配置,用注解方式来替代映射文件,但是注解配置还是有点不完善,在开发中使用比较少,大部分的企业还是在用映射文件来进行配置.不完善的地方体现在于当数据表中的字段 ...