求一个好的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看看

非常感谢
...全文
75 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)。
已经博主授权,源码转载自 https://pan.quark.cn/s/8f7d9b77a9d1 微信小程序是一个轻量级的应用开发平台,主要面向移动设备,由腾讯公司推出,其目的是提供一种便捷的应用体验,用户无需下载安装即可直接使用。"你画我猜"是一种广受欢迎的游戏模式,参与者通过绘画来传达一个词语或短语,其他参与者则根据所见的图画来猜测其含义,这种互动性突出且趣味盎然的模式非常适合在微信小程序平台上实现。在"微信小程序你画我猜游戏demo完整源码"这一资源中,我们可以学习到以下几个核心知识点:1. **微信小程序开发环境的构建**:开发者需要安装微信开发者工具,这是进行微信小程序编写与调试的基础。该工具集成了代码编辑、预览、调试等多种功能,为开发者提供了便利的项目开发条件。2. **WXML与WXSS**:WXML是微信小程序的结构性语言,类似于HTML,用于定义页面的结构与布局;WXSS是微信小程序的样式性语言,类似于CSS,负责控制页面的外观。开发者必须熟练掌握这两种语言的语法和特性,以便创建既美观又功能齐全的界面。3. **JavaScript的业务逻辑处理**:在微信小程序中,JavaScript主要承担数据绑定、事件处理以及API调用的职责。通过`Page`对象,开发者可以设定每个页面的数据、生命周期事件和方法,从而实现复杂的业务逻辑。4. **微信小程序API的应用**:此游戏demo会运用到微信小程序提供的多种API,包括用户身份验证、网络请、画板绘图、动画效果等。例如,`wx.createContext()` API可用于获取绘图环境,实现画板功能;`wx.request()`则用于与服务器进行交互,获取游戏数据或提交玩家的绘画作品。5. **游戏逻辑的...
内容概要:本文档是一套针对小说创作中人物“真实性”问题的诊断与生成系统,名为“真字门·人物真实性诊断与自性生成操作系统”。它通过“匕·目·乚”三步法(变形、看见、隐匿),帮助作者识别主角为何显得虚假(如提线木偶),并提供可操作工具重塑人物自性。系统包含十维诊断表、真假人物对比案例、真字人物卡模板及六尘感官指纹设计,强调人物应具备内在矛盾、隐藏动机与成长疼痛,而非仅服务于剧情的功能性角色。最终产出具有独特语言、行为与情感印记的真实生命体式角色,并支持向内容变现转化。; 适合人群:写作超过三个月但作品追读率低于20%的小说创作者,尤其适用于陷入角色扁平化、缺乏共鸣困境的新人或瓶颈期作者。; 使用场景及目标:①快速诊断现有主角的“真实度”缺陷,定位核心问题;②利用“真字人物生成器”在30分钟内重构具备心理层次、隐藏动机与成长弧光的角色;③为后续世界观构建、角色关系网及IP变现打下坚实基础。; 阅读建议:建议严格按照导读页顺序操作——先自测诊断分数,再对照案例找差距,最后动手填写空白人物卡模板;务必结合附录B的“林凡”示例反复比对,确保每一层设计都触及角色深层心理,避免停留在表面设定。
内容概要:本文围绕基于改进鲸鱼优化算法的微网系统能量优化管理展开研究,旨在通过智能优化算法提升微网系统的能源利用效率与运行经济性。研究构建了包含光伏发电、储能设备等多种分布式能源的微网系统模型,并以系统综合运行成本最小化为优化目标,提出一种改进的鲸鱼优化算法进行高效解,有效克服了传统优化算法易陷入局部最优、收敛速度慢等缺陷。通过Matlab平台进行仿真验证,结果表明该方法在降低微网运行成本、优化能量调度、平衡源荷关系以及提升可再生能源消纳能力方面具有显著优势,具备良好的科研价值与实际应用前景。; 适合人群:具备一定电力系统基础知识、优化算法理论背景,从事新能源发电、微电网运行与调度、智能优化算法研究等相关领域的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于微电网能量管理系统的建模与优化设计;②为智能优化算法在电力系统调度中的改进与工程应用提供典型案例;③支撑高水平学术论文撰写、算法复现与创新性研究工作。; 阅读建议:建议结合提供的Matlab代码进行仿真实践,重点分析算法的改进机制与微网系统模型的构建逻辑,对比原始鲸鱼算法的性能差异,深入理解目标函数设计、约束条件处理及参数调优策略,以全面提升科研与工程实践能力。

3,881

社区成员

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

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