区间交

Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 567    Accepted Submission(s): 279

Problem Description
小A有一个含有n个非负整数的数列与m个区间。每个区间可以表示为li,ri。

它想选择其中k个区间, 使得这些区间的交的那些位置所对应的数的和最大。

例如样例中,选择[2,5]与[4,5]两个区间就可以啦。

 
Input
多组测试数据

第一行三个数n,k,m(1≤n≤100000,1≤k≤m≤100000)。

接下来一行n个数ai,表示lyk的数列(0≤ai≤109)。

接下来m行,每行两个数li,ri,表示每个区间(1≤li≤ri≤n)。

 
Output
一行表示答案
 
Sample Input
5 2 3
1 2 3 4 6
4 5
2 5
1 4
 
Sample Output
10
 
Source
 
 
解题思路:首先排序右端点从小到大(也可以排序左端点,也可以从大到小排序,看怎么处理了),然后枚举右端点(保证所枚举的那个端点最少有k个区间可以覆盖)作为所求的交区间的右端点,这时候需要求出交区间的左端点,我们可以知道,右端点确定下,如果左端点越靠左,这个区间的范围约大。为了保证所交区间有k个,我们需要找到第k小的左端点,为了保证我枚举的右端点肯定是交区间的右端点,我们必须边枚举,边单点更新左端点。
 
  1. #include<stdio.h>
  2. #include<algorithm>
  3. #include<string.h>
  4. #include<math.h>
  5. #include<string>
  6. #include<iostream>
  7. #include<queue>
  8. #include<stack>
  9. #include<map>
  10. #include<vector>
  11. #include<set>
  12. using namespace std;
  13. typedef long long LL;
  14. #define mid (L+R)/2
  15. #define lson rt*2,L,mid
  16. #define rson rt*2+1,mid+1,R
  17. #pragma comment(linker, "/STACK:102400000,102400000")
  18. const int maxn = 1e5+300;
  19. const int INF = 0x3f3f3f3f;
  20. typedef long long LL;
  21. typedef unsigned long long ULL;
  22. LL presum[maxn];
  23. struct Interval{
  24. int l, r;
  25. }intervals[maxn];
  26. struct Seg{
  27. int cover;
  28. }segs[maxn*4];
  29. bool cmp(Interval a, Interval b){
  30. return a.r < b.r; //
  31. }
  32. void PushUp(int rt){
  33. segs[rt].cover = segs[rt*2].cover + segs[rt*2+1].cover;
  34. }
  35. void buildtree(int rt,int L,int R){
  36. if(L == R){
  37. segs[rt].cover = 0;
  38. return;
  39. }
  40. buildtree(lson);
  41. buildtree(rson);
  42. PushUp(rt);
  43. }
  44. void Update(int rt,int L,int R,int id){
  45. if(L == R){
  46. segs[rt].cover++;
  47. return ;
  48. }
  49. if(id <= mid){
  50. Update(lson,id);
  51. }else{
  52. Update(rson,id);
  53. }
  54. PushUp(rt);
  55. }
  56. int query(int rt,int L, int R,int k){
  57. if(L == R){
  58. return L;
  59. }
  60. if(k <= segs[rt*2].cover){
  61. return query(lson,k);
  62. }else{
  63. return query(rson,k-segs[rt*2].cover);
  64. }
  65. }
  66. int main(){
  67. int n, k, m;
  68. while(scanf("%d%d%d",&n,&k,&m)!=EOF){
  69. buildtree(1,1,n);
  70. LL a;
  71. for(int i = 1; i <= n; i++){
  72. scanf("%lld",&a);
  73. presum[i] = presum[i-1] + a;
  74. }
  75. int l, r;
  76. for(int i = 1; i <= m; i++){
  77. scanf("%d%d",&l,&r);
  78. intervals[i].l = l;
  79. intervals[i].r = r;
  80. }
  81. sort(intervals+1,intervals+1+m,cmp);
  82. for(int i = m-k+1; i <= m; i++){
  83. Update(1,1,n,intervals[i].l);
  84. }
  85. LL ans = 0;
  86. for(int i = m-k+1; i >= 1; i--){
  87. int l = query(1,1,n,k);
  88. if(l <= intervals[i].r){
  89. ans = max(ans, presum[intervals[i].r] - presum[l-1]);
  90. }
  91. Update(1,1,n,intervals[i-1].l);
  92. }
  93. printf("%lld\n",ans);
  94. }
  95. return 0;
  96. }
  97.  
  98. /*
  99. 5 1 1
  100. 1 2 3 4 6
  101. 4 5
  102.  
  103. 3 4
  104.  
  105. */

  

 

HDU 5700——区间交——————【线段树+枚举】的更多相关文章

  1. hdu 5700区间交(线段树)

    区间交 Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submiss ...

  2. HDU 5700 区间交 线段树暴力

    枚举左端点,然后在线段树内,更新所有左边界小于当前点的区间的右端点,然后查线段树二分查第k大就好 #include <cstdio> #include <cstring> #i ...

  3. HDU 5700 区间交 离线线段树

    区间交 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5700 Description 小A有一个含有n个非负整数的数列与m个区间.每个区间可以表示为 ...

  4. HDU 5700 区间交(线段树)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5700 [题目大意] 给出一个长度为n的数列和m个区间,现在求k个区间,使得他们的区间交内的数列项和 ...

  5. HDU 5700 区间交

    枚举起点 二分终点 树状数组check #include<iostream> #include<cstring> #include<cmath> #include& ...

  6. HDU 1540 区间合并线段树

    题目大意: 就是给定一堆位置,进行删除还原,最后找到 t 位置上的最大连续位置 #include <cstdio> #include <cstring> #include &l ...

  7. Snacks HDU 5692 dfs序列+线段树

    Snacks HDU 5692 dfs序列+线段树 题意 百度科技园内有n个零食机,零食机之间通过n−1条路相互连通.每个零食机都有一个值v,表示为小度熊提供零食的价值. 由于零食被频繁的消耗和补充, ...

  8. 【题解】P1712 [NOI2016]区间(贪心+线段树)

    [题解]P1712 [NOI2016]区间(贪心+线段树) 一个observe是,对于一个合法的方案,将其线段长度按照从大到小排序后,他极差的来源是第一个和最后一个.或者说,读入的线段按照长度分类后, ...

  9. 【BZOJ4653】【NOI2016】区间(线段树)

    [BZOJ4653][NOI2016]区间(线段树) 题面 BZOJ 题解 \(NOI\)良心送分题?? 既然是最大长度减去最小长度 莫名想到那道反复减边求最小生成树 从而求出最小的比值 所以这题的套 ...

随机推荐

  1. TSQL--可以在触发器中使用COMMIT吗?

    很多场景中,我们使用触发器来回滚一些不满足业务逻辑的修改,这没有问题,问题是我能在触发器中提交事务吗? 这个问题很小白,当也来测试一下 /*测试中创建三种表,对表 TB2 插入时触发触发器,在触发器中 ...

  2. RobotFramework的Setup和Teardown

    测试套件级别的Setup会在本套件测试用例集合执行前先执行,同理Teardown会在本组所有用例执行完成后运行 测试用例级别的Setup会在本条测试用例执行前先执行,同理Teardown会在本条用例执 ...

  3. BlangenOA项目展示(附源码)

    1. 登录界面 1.1表单校验 1.2信息有误 1.3正在登录   2.桌面 3.用户管理 3.1添加 3.2删除 3.3编辑 3.4设置用户角色 3.5设置用户权限 4.角色管理 5.权限管理(菜单 ...

  4. 2、ASP .NETCore 2.0之视图

    一.Razor基础 声明:Razor不是编程语言,是服务器端标记语言.Razor是一种允许开发者在网页中嵌入服务器端代码的标记语法(主要是针对VB和C#). 1.C#中Razor基本语法 (1).Ra ...

  5. Nginx源码编译

    1. 概述 有时由于添加了自己编写的c++模块,或者改了源码的一些名称.配置什么的,需要自行编译nginx. 可以先下下来源码,然后需要的话就自己改下源码或增加模块,最后再编译成linux或者wind ...

  6. numpy数组 拼接

    转载自:https://blog.csdn.net/zyl1042635242/article/details/43162031 数组拼接方法一 首先将数组转成列表,然后利用列表的拼接函数append ...

  7. jQuery判断表单input

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. “全栈2019”Java第七十五章:内部类持有外部类对象

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  9. Centos6和7的区别

    1.init系统 Linux 操作系统的启动首先从 BIOS 开始,接下来进入 boot loader,由 bootloader 载入内核,进行内核初始化.内核初始化的最后一步就是启动 pid 为 1 ...

  10. 多继承c3算法

    一.mro mro即 method resolution order (方法解释顺序),主要用于在多继承时判断属性的路径(来自于哪个类). print(类.mro)得到属性路径按继承顺序 在pytho ...