设有n个活动的集合E={1,2,…,n},其中每个活动都要求使用同一资源,如演讲会场等,而在同一时间内只有一个活动能使用这一资源。
每个活动i都有一个要求使用该资源的起始时间si和一个结束时间fi,且si<fi。如果选择了活动i,则它在半开时间区间[si ,fi )内占用资源。若区间[si ,fi )与区间[sj,fj )不相交,则称活动i与活动j是相容的。当 si ≥ fj 或 sj ≥ fi 时,活动i与活动j相容。
活动安排问题就是在所给的活动集合中选出最大的相容活动子集合。
把活动的起始时间和结束时间定义为结构体:
struct action{
int s;
int f;
int index;
};
活动集合E记为数组:
action a[1000];
按活动的结束时间升序排序
排序比较因子:
bool cmp(const action &a, const action &b)
{
if (a.f<=b.f) return true;
return false;
}
使用标准模板库函数排序(下标0未用):
sort(a, a+n+1, cmp);
void Greedy(vector<Action> &v,int n){
v[0].select=1;
int select=0;
for(int i=1;i<n;i++) {
if(v[i].gets()>=v[select].gete()){
v[i].select=1;
select=i;
}
}
cout<<"可以安排如下的活动:"<<endl;
for(i=0;i<n;i++)
if(v[i].select)
v[i].display();
}