在学习算法过程中遇到一个题是一个数组 events,其中 events[i] = [startDayi, endDayi] ,表示会议 i 开始于 startDayi ,结束于 endDayi 。你可以在满足 startDayi <= d <= endDayi 中的任意一天 d 参加会议 i 。注意,一天只能参加一个会议。返回你可以参加的 最大 会议数目。 我想知道的是大家解释一下贪心算法
2条回答 默认 最新
关注 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; } };
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥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使用得具体信息,干了什么,传输了什么数据