`
默默的小熊
  • 浏览: 235844 次
社区版块
存档分类
最新评论

活动安排问题

 
阅读更多

    设总共有n项活动(1,2,...,n),并且所有的活动都需要使用同一个会场,而且任意两个活动不能同时使用这个会场。设活动i占用会场的时间是[bi,ei),其中bi<ei(bi是活动i的开始时间,ei是活动的结束时间),那么怎么安排才能使该会场有尽可能多的活动。

    1. 最先想到的一个简单模型

    有一个容器,容量为K,有n杯水,体积按小到大分别为L1, L2, ..., Ln,要尽可能往容器中倒入最多杯的水,那么我们会一直选当前最小杯的水往里面倒,直到下一杯水倒不完就停止。这个模型好像有点跟上面的活动安排差不多,也有一个给定的范围,也是求最大值。那是不是活动安排的例子中,我们总是去选时间最短的活动呢?

    2. 从找最短活动时间考虑

    记当前的活动集为S,已选出的活动集为X

    (1) 找到活动时间最短的k,把它从活动集S中去除,加入到X集中,同时把和K它不相容的活动从S中去除;

    (2) 反复执行过程1,直到x中的活动时间和大于要求的数;

    (3) 去除x中最后一个活动,X就是所求的活动集,X中元素的个数就是允许的最大活动个数;

但是这样可以吗?    有问题!!)

    如果本题是:有N个时间单位,n项活动进行的时间分别为t1,t2,...,tn,各项活动不一定要在某个时间段完成,那么活动也就没有相容问题,那么可以找时间最短的活动。

    然而现在找时间最短是会出问题的:可以看一个例子:

 

//	#########      ####      ########
//            ######  #####

   上图的#是活动的表示,#的多少表示活动时间的长短,上图总共有5个活动,但是若按最短活动时间来选,就只有3个活动,但实际能进行的活动有4个,所以从最短时间来选是有问题的。

    3. 从找开始最早的活动选起

    这种选法还是会有问题,见下图:

 

//	####################
//     ######  #####

    最早活动开始时间考虑的话,只有1个活动,而实际最大可以有两个。

    3. 从最早结束的活动找起

    这个是可行的,具体证明还在想。。。

    简单实现:

    public static void main(String[] args) {

		int[] b = { 1, 3, 0, 5, 3, 5, 6, 8, 8, 2, 12 };
		int[] e = { 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14 };
		
		int endTime = 0;   //当前活动的结束时间,初始化0
		
		for(int i = 0; i < b.length; i++){
			if(b[i] >= endTime){
				System.out.print(i + " ");
				endTime = e[i];
			}
		}

	}
 

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    活动安排问题.rar

    活动安排问题是一个经典的计算机科学问题,常常出现在算法课程中,特别是在哈工程的算法课程中作为实验项目出现。这个问题的核心是优化一系列活动的安排,使得在满足特定约束条件下,尽可能多地完成活动。这个问题在...

    浅谈Python实现贪心算法与活动安排问题

    在Python中,我们可以利用贪心策略来解决一些特定的问题,比如活动安排问题。 活动安排问题是一个典型的贪心算法应用场景。假设有一系列的活动,每个活动都有开始时间和结束时间,目标是找出能够参加的最大数量的不...

    贪心算法活动安排问题,

    ### 贪心算法在活动安排问题中的应用 #### 一、引言 在计算机科学领域,贪心算法是一种在每个步骤中都选择局部最优解的策略,希望通过这种方式找到全局最优解。活动安排问题(Activity Selection Problem)是贪心...

    C++贪心算法实现活动安排问题(实例代码)

    C++贪心算法实现活动安排问题实例代码 C++贪心算法是一种常用的算法思想,贪心算法的核心思想是,每一步都采取当前最优的选择,以期望达到全局最优的解。贪心算法的应用非常广泛,如活动安排问题、Huffman编码、...

    活动安排问题 贪心法——C++代码

    在活动安排问题中,可能涉及将多个活动按照结束时间排序,每次都选择最早结束的活动,以尽可能多地参加活动。 2. **数据结构**:可能需要使用数组或链表来存储活动信息,如开始时间、结束时间和活动ID等。 3. **...

Global site tag (gtag.js) - Google Analytics