算法分析与实践10

1.问题
相容问题,解析时给出其他几种贪心策略(如按开始时间从小到大、每个活动时间的占用时间等),并给出这些贪心策略无法实现最优的反例。
问题描述
有n项活动申请使用同一个礼堂,每项活动有一个开始时间和一个截止时间。如果任何两个活动不能同时举行,问如何选择这些活动,从而使得被安排的活动数量达到最多。
2.解析
建模:设S={1,2,…,n}为活动的集合,si和fi分别为活动i的开始和截止时间,i=1,2,…,n
定义:活动i和j相容 si>=fi或sj>=fi,i≠j
求S最大的两两相容的活动子集A。

按开始时间从小到大
在这里插入图片描述
3.设计
A={1}
j = 1
for i = 2 to n
if si >= fj
A = A∪i
return A
4.分析
时间复杂度为O(n)
5.源码
https://github.com/xujinyuanky/-/blob/master/%E7%AE%97%E6%B3%95%E5%88%86%E6%9E%9010%20%E7%9B%B8%E5%AE%B9%E9%97%AE%E9%A2%98

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值