【贪心算法】算法导论—活动选择问题Activity-Selection (Java实现)

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);
        }
    }
}

输出:
在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值