掩月天权 2022-11-21 10:44 采纳率: 66.7%
浏览 6
已结题

关于#算法#的问题,如何解决?

在学习算法过程中遇到一个题是一个数组 events,其中 events[i] = [startDayi, endDayi] ,表示会议 i 开始于 startDayi ,结束于 endDayi 。你可以在满足 startDayi <= d <= endDayi 中的任意一天 d 参加会议 i 。注意,一天只能参加一个会议。返回你可以参加的 最大 会议数目。 我想知道的是大家解释一下贪心算法

  • 写回答

2条回答 默认 最新

  • 肩匣与橘 游戏开发领域新星创作者 2022-11-21 10:58
    关注
    
    class Solution {
    public:
        int maxEvents(vector<vector<int>>& events) {
            sort(events.begin(), events.end());
            priority_queue<int,vector<int>, greater<int>> q;//小顶堆,结束时间早的,先出队
            int count = 0, i = 0, time = 0;
            while(i < events.size() || !q.empty())
            {
                time++;
                while(!q.empty() && q.top() < time)//结束时间过去了,该会议删除
                    q.pop();
                while(i < events.size() && events[i][0] == time)
                {
                    q.push(events[i][1]);//time时间,会议i开始了,把他的结束时间push进去
                    i++;
                }
                if(!q.empty())
                {
                    count++;
                    q.pop();//最早结束的先参加
                }
            }
            return count;
        }
    };
    
    

    贪心算法:https://zhuanlan.zhihu.com/p/76164082

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 11月29日
  • 已采纳回答 11月21日
  • 创建了问题 11月21日

悬赏问题

  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据