博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
求多个区间合并后区间大小的巧妙解决方法【差分】
阅读量:5063 次
发布时间:2019-06-12

本文共 1077 字,大约阅读时间需要 3 分钟。

  上图一共有5个区间,分别是[0,2]、[2,4]、[8,11]、[7,11]、[15,18]。如果要求这些区间合并后区间的大小,有两种简单的方法。

  方法一:比较每两个区间的范围,如果两个区间有交集,则合并它们。最后所有区间会合并成几个离散的大区间,结果为这些区间大小之和。这种方法的时间复杂度是O(n^2)。

  方法二:使用一个可以覆盖所有区间范围的数组,对每个区间进行标记,结果为数组中被标记元素的个数。这种方法的时间复杂度是O(nm)。

  注:n是区间个数,m是所有区间总的范围。

 

  如果n和m都比较大,那么上述两种方法的效率都不高。这里有一种很巧妙的解决这个问题的方法,它的时间复杂度是O(n+m)。使用一个可以覆盖所有区间范围的数组flg,初始化时将数组中的元素都置为0。对于每一个区间[l,r],将flg[l]++,flg[r+1]--。最后使用一个累加器cnt,初始置为0。依次扫描数组中的每一个元素,对于第i个元素,cnt+=flg[i]。此时,若cnt>0,则说明i在某些区间中;若cnt==0,则证明i不在任何区间中。统计cnt>0的元素个数即可。

#include 
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;#define ll long longconst double PI = acos(-1.0);const int maxn = 101;const int INF = 0x3f3f3f3f;int dx[]={ 0,0,-1,1};int dy[]={-1,1,0,0};int n,m;int f[maxn],cnt=0,sum=0;struct node{ int l,r;}a[maxn];int main(){ scanf("%d%d",&n,&m); for(int i=0;i
0) cnt++; } printf("%d\n",cnt);}

 

转载于:https://www.cnblogs.com/Roni-i/p/9565158.html

你可能感兴趣的文章
MFC的初始化过程和消息映射技术
查看>>
Windows中使用Mysql-Proxy实现Mysql读写分离
查看>>
编程之美 set 5 寻找数组中最大值和最小值
查看>>
[百度空间] [原] Empty base class optimization
查看>>
keycode对照表
查看>>
BZOJ3444: 最后的晚餐
查看>>
ConnectionPoolTimeoutException: Timeout waiting for connection
查看>>
HorizontalScrollView实现先左滑动后右滑动动画
查看>>
编译Android系统源码(高通平台)
查看>>
The packages can be overrided by Java Endorsed Standards
查看>>
彻底理解android中的内部存储与外部存储
查看>>
电子商务系统的设计与实现(六):账务系统服务化的好处和坏处
查看>>
URLconf+MTV:Django眼中的MVC(zz)
查看>>
单词数 hdu 2072
查看>>
Mysql | 查询
查看>>
利用nginx concat模块合并js css
查看>>
linux文件夹下载
查看>>
缓冲流
查看>>
Android - ANR小结
查看>>
cocos2d-x 中使用 srand((unsigned)time(NULL))重新设置一个随机种子
查看>>