内容:
给定 n 个闭区间 [ai; bi],其中i=1,2,…,n。任意两个相邻或相交的闭区间可以合并为一个闭区间。例如,[1;2] 和 [2;3] 可以合并为 [1;3],[1;3] 和 [2;4] 可以合并为 [1;4],是[1;2] 和 [3;4] 不可以合并
分析:
定义区间结构体进行存储并定义比较函数
将输入的区间组排序后,左右两边进行分治,直至缩小到两个小区间合并问题
如果不能合并,程序输出no并直接退出
如果可以,分治结束后结果合并即可得到最终区间
代码:
//区间合并
#include
#include
#define N 100
using namespace std;
struct Interval{
int left,right;
};
bool compareInterval(Interval,Interval);
Interval intervalMerge(Interval[],int,int);
int main()
{
Interval interval[N];
int n;
cout<<“请输入区间数量:”;
cin>>n;
for(int i=0;i<n;i++)
cin>>interval[i].left>>interval[i].right;
sort(interval,interval+n,compareInterval);
Interval tempInterval = intervalMerge(interval,0,n-1);
cout<<tempInterval.left<<" "<<tempInterval.right<<endl;
return 0;
}
bool compareInterval(Interval mLeft,Interval mRight){
if(mLeft.left < mRight.left)
return true;
return false;
}
Interval intervalMerge(Interval internal[],int left,int right){
if(left == right)
return internal[left];
Interval tempInterval1 = intervalMerge(internal,left,(left+right)/2),
tempInterval2 = intervalMerge(internal,(left+right)/2+1,right);
if(tempInterval1.right >= tempInterval2.left){ //符合合并条件 进行合并
Interval tempInterval;
tempInterval.left = tempInterval1.left;
tempInterval.right = tempInterval1.right>=tempInterval2.right
?tempInterval1.right
:tempInterval2.right;
return tempInterval;
}else{
cout<<“no”<<endl;
exit(0);
}
}