求一个好的emerge ranges的算法

bbzhuanyong 2010-08-25 10:16:43
我有一大堆互相overlapping的ranges
比如
1:6
2:5
1:5
3:7

8:12
11:17
....

想把这些那些overlappi的ranges合在一起,最终整理成几个长长的range

请教有什么优雅的算法或者sample code看看

非常感谢
...全文
78 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
Jim_King_2000 2010-08-26
  • 打赏
  • 举报
回复
顶一下。
baihacker 2010-08-26
  • 打赏
  • 举报
回复
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <iterator>
#include <iostream>
using namespace std;
#define pb push_back
#define mp make_pair
#define X first
#define Y second
int main()
{
int data[] = {1,6,2,5,1,5,3,7,8,12,11,17};
const int size = sizeof (data) / sizeof (data[0]);
vector<pair<int, int> > vec, result;
for (int i = 0; i < size; i += 2) vec.pb(mp(data[i], data[i+1]));
sort(vec.begin(), vec.end());
int u = vec[0].X, v = vec[0].Y;
for (int i = 1; i < vec.size(); ++i)
{
if (vec[i].X <= v)
{
if (vec[i].Y > v) v = vec[i].Y;
}
else
{
result.pb(mp(u, v));
u = vec[i].X, v = vec[i].Y;
}
}
result.pb(mp(u, v));
for (int i = 0; i < result.size(); ++i)
cout << result[i].X << " " << result[i].Y << endl;
return 0;
}
xy_zhang 2010-08-26
  • 打赏
  • 举报
回复
呃…… 又想到一种用bitmap的办法。

先从输入的range中取出最大数,作为bitmap的大小,然后依次读入这些range,把相应的位置1。这样所有的range读完,再把bitmap中连续的1整理成新的range。

前面一种方法比较适合输入range对数不多,但是数值很大的情况。
后面一种方法比较适合range比较零碎比较多,但是最大值不是很大的情况。
xy_zhang 2010-08-25
  • 打赏
  • 举报
回复
抛砖引玉下~
能想到最直接的办法:
把所有的数看成(begin, end)对
1. 把所有的pair按照begin来排序。
2. 从一个pair开始,取range_begin为该pair的begin,range_end为该pair的end。
3. range_end与下一个数的begin比较,如果range_end较小,输出range_begin和range_end,这就是一个不重叠的区间。然后从下一个pair开始,重复2。
4. 否则,即range_end大于下一个数的begin,更新range_end为max(range_end, end),然后继续3。直至所有pair比较完毕。

这里由于要排序,时间复杂度为O(NlogN)。
内容概要:本文系统阐述了嵌入式功能安全领域的两大核心标准——IEC 61508与ISO 26262的完整体系,涵盖其定位、关系、技术要及认证流程。IEC 61508作为通用工业功能安全基础标准,适用于PLC、机器人、轨道交通等系统,采用SIL等级划分;ISO 26262则是其在汽车行业的衍生标准,专用于车载电控单元(如BMS、ESP、自动驾驶控制器),采用ASIL等级评估。文章详细解析了两个标准在风险评估方法(如HARA与风险图法)、软硬件设计规范、失效分析、安全机制实现(如看门狗、CRC校验、冗余设计)等方面的异同,并提供了从需分析到认证落地的全流程实施路径,包括安全生命周期管理、文档证据链构建及第三方认证机构介绍。; 适合人群:从事工业自动化或汽车电子领域嵌入式系统设计、功能安全开发与认证工作的工程师、项目经理及安全分析师,具备一定电子电气或软件开发背景的专业人员; 使用场景及目标:①指导企业开展符合IEC 61508或ISO 26262的功能安全产品设计与认证;②帮助研发团队理解SIL/ASIL等级判定逻辑与软硬件安全机制实现方式;③支持撰写安全需文档、FMEDA报告及准备第三方审核材料; 阅读建议:此资源兼具理论体系与工程实践,建议结合具体项目场景对照标准条款进行研读,并重点关注安全生命周期各阶段的交付物要与典型安全防护设计示例,以提升实际应用能力。

3,881

社区成员

发帖
与我相关
我的任务
社区描述
C/C++ 其它技术问题
社区管理员
  • 其它技术问题社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧