1 背景描述
给你n个活动的开始时间和结束时间,从中选择你可以参与的活动,但是同一时间你只能参与一个活动,请找出你可以参与的最大活动数。
2 算法思路
贪心算法直接在每一步选择当前看来最好的选择。在选择开始时,选择活动结束时间最早的那个活动,这样能够给其他活动尽可能的腾出多余的时间。而后每一步都在剩余的活动中选取,也遵循类似的原则。
在解决活动选择问题时,选择其余活动中完成时间最短的下一个活动,并且开始时间大于或等于先前所选活动的结束时间。我们可以根据他们的完成时间对活动进行排序,以便我们始终将下一个活动视为最小完成时间对活动。
- 根据完成时间对活动进行排序
- 从排序的数组中选择第一个活动并输出
- 对已排序的数组中的剩余活动执行以下操作:如果此活动的开始时间大于或等于先前所选活动的结束时间,则选择此活动并输出。
3 算法实现
Java代码涉及class类、List列表、Collections类自定义排序的相关知识
import java.util.*;
/**
* @Author wzp
* @Date
* @Description 活动选择(贪心算法)
*/
public class ActivitySelection {
int id; //活动序号ID
int start; // 活动开始时间
int finish; // 活动结束时间
// 构造方法
public ActivitySelection(int id,int start,int finish){
this.id = id;
this.finish = finish;
this.start = start;
}
public static void main(String[] args) {
// 定义活动
ActivitySelection a1 = new ActivitySelection(1,0,6);
ActivitySelection a2 = new ActivitySelection(2,1,2);
ActivitySelection a3 = new ActivitySelection(3,3,4);
ActivitySelection a4 = new ActivitySelection(4,5,7);
ActivitySelection a5 = new ActivitySelection(5,5,9);
ActivitySelection a6 = new ActivitySelection(6,8,9);
// 放入列表
List<ActivitySelection> list = new LinkedList<>();
list.add(a1);
list.add(a2);
list.add(a3);
list.add(a4);
list.add(a5);
list.add(a6);
System.out.println("活动如下");
printActivitylist(list);
// 根据活动的finish结束时间进行排序
Collections.sort(list, new Comparator<ActivitySelection>() {
@Override
public int compare(ActivitySelection o1, ActivitySelection o2) {
if(o1.finish>o2.finish)return 1;
else return -1;
}
});
System.out.println("排序后(按结束时间排序)");
printActivitylist(list); // 输出活动list
System.out.println("选择的活动id如下");
// 选择第一个活动
System.out.print(list.get(0).id+" ");
int fin = list.get(0).finish;// 记录第一个活动的结束时间
for(int i=1;i<list.size();i++){
if(list.get(i).start >= fin){
System.out.print(list.get(i).id+" ");
fin = list.get(i).finish; // 更新最后一个被选中活动的结束时间
}
}
}
/**
* 打印输出list的工具方法
* @param list
*/
private static void printActivitylist(List<ActivitySelection> list) {
for(ActivitySelection activitySelection:list){
System.out.println("id:"+activitySelection.id+" start:"+
activitySelection.start+" finish:"+activitySelection.finish);
}
}
}
输出: