贪心算法-会议室问题

1、题目描述

一些项目要占用一个会议室宣讲,会议室不能同时容纳两个项目。现在给你两个长度一样的数组,starts数组代码每个会议开始的时间,ends数组代表每个会议结束的时间。

在给你一个当前时间,请你求出当日可以利用会议室宣讲的最大值

思路分析:

1.按照最早开始的会议排序,最早开始的优先。

2.按照最短时间排序,时间最短的优先。

3.按照最早结束排序,最早结束的优先。

贪心算法是纯粹的积累经验类型的算法思想,贪心策略的正确性证明是非常困难的,几乎不可能证明正确性,因此,只能通过对数器进行验证。同时,可以举反例排除错误的贪心策略。

比如上面的:

1.如果最早开始的会议时间是最长呢?直接怼一天的话,显然不合理对吧?

2.如果最短的会议在中间呢?导致它前面的时间浪费了,后面的时间可能正好差一点不够一个会议,这样也很浪费,肯定不是最优解。

因此,排除掉1和2,此题的最优贪心算法应该就是3。

解题思路:
是按照项目完成时间,从前到后排序,先做最早结束的项目,然后淘汰掉不能再做的项目

c 复制代码
public static class Program {
   public int start;
   public int end;

   public Program(int start, int end) {
      this.start = start;
      this.end = end;
   }
}
// 会议的开始时间和结束时间,都是数值,不会 < 0
public static int bestArrange2(Program[] programs) {
   Arrays.sort(programs, new ProgramComparator());
   int timeLine = 0;
   int result = 0;
   // 依次遍历每一个会议,结束时间早的会议先遍历
   for (int i = 0; i < programs.length; i++) {
      if (timeLine <= programs[i].start) {
         result++;
         timeLine = programs[i].end;
      }
   }
   return result;
}

public static class ProgramComparator implements Comparator<Program> {

   @Override
   public int compare(Program o1, Program o2) {
      return o1.end - o2.end;
   }

}
相关推荐
闪电麦坤9537 分钟前
数据结构:数组:合并数组(Merging Arrays)
数据结构·算法
C++ 老炮儿的技术栈1 小时前
tinyxml2 开源库与 VS2010 结合使用
c语言·数据结构·c++·算法·机器人
平平无奇我要摘星星1 小时前
leetcode1_455.分发饼干
算法·leetcode
Joern-Lee2 小时前
机器学习算法:支持向量机SVM
算法·机器学习·支持向量机
秋说2 小时前
【PTA数据结构 | C语言版】计算1~n与1~m每一项相互乘积的和
c语言·数据结构·算法
秋说2 小时前
【PTA数据结构 | C语言版】计算1~n平方的和加上1~n的和
c语言·数据结构·算法
C++ 老炮儿的技术栈2 小时前
Visual Studio 2022 MFC Dialog 添加Toolbar及Tips提示
服务器·c语言·数据库·c++·ide·算法·visual studio
水果里面有苹果2 小时前
18-C#改变形参内容
java·数据结构·算法
前端拿破轮2 小时前
女朋友要和我分手?!!居然是因为交不出赎金信,不会用哈希表😭😭😭
算法·leetcode·typescript
CoovallyAIHub3 小时前
基于YOLOv11的CF-YOLO,如何突破无人机小目标检测?
深度学习·算法·计算机视觉