编程练习9 会议室占用时间段

这个主要是对边界条件的处理需要注意,比如只有一个会议,两个会议以及重叠与不重叠各种情况。

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

struct MeetingTime {
    int start;
    int end;
};

bool compare(const MeetingTime &a, const MeetingTime &b) {
    return a.start < b.start;
}

int main() {
	int meeting_num = 0;
	cin >> meeting_num;
	vector<MeetingTime> meetings;
    for (int i = 0; i < meeting_num; i++) 
	{
		MeetingTime a;
		cin >> a.start >> a.end;
		meetings.push_back(a);
    }
    
    // 假设已经通过某种方式填充了meetings向量
    // 例如:meetings = {{1, 4}, {2, 5}, {7, 9}, {14, 18}};
    
    // 排序
    sort(meetings.begin(), meetings.end(), compare);
    
    // 合并时间段
    vector<MeetingTime> merged;
	int meetings_num = meetings.size();
    for (int i = 0; i < meetings_num; ++i) {
		//如果只有一个会议 直接输出
		if(meetings.size() == 1)
		{
			merged.push_back(meetings[i]);
		}
		//如果当前会议时间和后面一个会议重叠 则需要将两次会议合并 直接将合并后的会议替换下一个会议时间
        else if (meetings[i].end >= meetings[i + 1].start && i<meetings_num-1) 
		{
            MeetingTime curr = meetings[i];
            if (meetings[i].end < meetings[i + 1].end) {
                curr.end = meetings[i + 1].end;
            }
			
			meetings[i + 1].start = curr.start;
			meetings[i + 1].end = curr.end;		
        }
		else
		{
			//如果是倒数第二个会议 需要单独处理
			if(i == meetings.size()-2)
			{
				//如果与最后一个会议不重叠 则将当前会议输出
				if(meetings[i].end < meetings[i + 1].start)
				{
					merged.push_back(meetings[i]);
					//merged.push_back(meetings[i+1]);
				}
				else if(meetings[i].end >= meetings[i + 1].start)
				{
					 MeetingTime curr = meetings[i];
					if (meetings[i].end < meetings[i + 1].end) {
						curr.end = meetings[i + 1].end;
					}
					merged.push_back(curr);
				}

			}
			else
			{
				merged.push_back(meetings[i]);
			}
		}
		
    }
    
    // 输出结果
    for (const auto &m : merged) {
        cout << m.start << " " << m.end << endl;
    }
    
    return 0;
}
相关推荐
仰泳的熊猫2 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
无极低码5 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发6 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
Thera7776 小时前
C++ 高性能时间轮定时器:从单例设计到 Linux timerfd 深度优化
linux·开发语言·c++
罗超驿6 小时前
独立实现双向链表_LinkedList
java·数据结构·链表·linkedlist
superior tigre6 小时前
22 括号生成
算法·深度优先
君义_noip7 小时前
信息学奥赛一本通 1952:【10NOIP普及组】三国游戏 | 洛谷 P1199 [NOIP 2010 普及组] 三国游戏
c++·信息学奥赛·csp-s
努力也学不会java8 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎8 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针