leetcode 731. 我的日程安排表 II

实现一个程序来存放你的日程安排。如果要添加的时间内不会导致三重预订时,则可以存储这个新的日程安排。

当三个日程安排有一些时间上的交叉时(例如三个日程安排都在同一时间内),就会产生 三重预订

事件能够用一对整数 startTimeendTime 表示,在一个半开区间的时间 [startTime, endTime) 上预定。实数 x 的范围为 startTime <= x < endTime

实现 MyCalendarTwo 类:

  • MyCalendarTwo() 初始化日历对象。
  • boolean book(int startTime, int endTime) 如果可以将日程安排成功添加到日历中而不会导致三重预订,返回 true。否则,返回 false 并且不要将该日程安排添加到日历中。

示例 1:

复制代码
输入:
["MyCalendarTwo", "book", "book", "book", "book", "book", "book"]
[[], [10, 20], [50, 60], [10, 40], [5, 15], [5, 10], [25, 55]]
输出:
[null, true, true, true, false, true, true]

解释:
MyCalendarTwo myCalendarTwo = new MyCalendarTwo();
myCalendarTwo.book(10, 20); // 返回 True,能够预定该日程。
myCalendarTwo.book(50, 60); // 返回 True,能够预定该日程。
myCalendarTwo.book(10, 40); // 返回 True,该日程能够被重复预定。
myCalendarTwo.book(5, 15);  // 返回 False,该日程导致了三重预定,所以不能预定。
myCalendarTwo.book(5, 10); // 返回 True,能够预定该日程,因为它不使用已经双重预订的时间 10。
myCalendarTwo.book(25, 55); // 返回 True,能够预定该日程,因为时间段 [25, 40) 将被第三个日程重复预定,时间段 [40, 50) 将被单独预定,而时间段 [50, 55) 将被第二个日程重复预定。

提示:

  • 0 <= start < end <= 10^9
  • 最多调用 book 1000 次。

分析:第 729 题的进阶版本,区间需要重复三次才不能预定。由于 book 最多调用1000次,因此还是可以用直接遍历的方法来解决这道题。

相应地需要修改 MyCalendarTwo,除了记录可以被预定的日程,还需要记录已经被预定过两次的区间。对于每次预定,首先在已经预定过两次的区间上查询,如果存在交集,说明不能够预定;否则可以预定,把这次预定的区间,以及这次预定的区间与之前预定的区间所产生的重复预定区间存下来。

cpp 复制代码
typedef struct {
    int booksize;
    int *book;
    int overlapsize;
    int *overlop;
} MyCalendarTwo;


MyCalendarTwo* myCalendarTwoCreate() {
    MyCalendarTwo *my=(MyCalendarTwo*)malloc(sizeof(MyCalendarTwo));
    my->booksize=my->overlapsize=0;
    my->book=(int*)malloc(sizeof(int)*2020);
    my->overlop=(int*)malloc(sizeof(int)*2020);
    return my;
}

bool myCalendarTwoBook(MyCalendarTwo* obj, int startTime, int endTime) {
    for(int i=0;i<obj->overlapsize;i++)
        if(startTime<obj->overlop[i*2+1]&&endTime>obj->overlop[i*2])
            return false;

    for(int i=0;i<obj->booksize;i++)
    {
        if(startTime<obj->book[i*2+1]&&endTime>obj->book[i*2])
        {
            obj->overlop[obj->overlapsize*2]=fmax(obj->book[i*2],startTime);
            obj->overlop[obj->overlapsize*2+1]=fmin(obj->book[i*2+1],endTime);
            obj->overlapsize++;
        }
    }
    obj->book[obj->booksize*2]=startTime;
    obj->book[obj->booksize*2+1]=endTime;
    obj->booksize++;
    return true;
}

void myCalendarTwoFree(MyCalendarTwo* obj) {
    free(obj->book);
    free(obj->overlop);
    free(obj);
    return;
}

/**
 * Your MyCalendarTwo struct will be instantiated and called as such:
 * MyCalendarTwo* obj = myCalendarTwoCreate();
 * bool param_1 = myCalendarTwoBook(obj, startTime, endTime);
 
 * myCalendarTwoFree(obj);
*/
相关推荐
_不会dp不改名_13 小时前
leetcode_21 合并两个有序链表
算法·leetcode·链表
吃着火锅x唱着歌13 小时前
LeetCode 3302.字典序最小的合法序列
leetcode
睡不醒的kun13 小时前
leetcode算法刷题的第三十四天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
吃着火锅x唱着歌13 小时前
LeetCode 978.最长湍流子数组
数据结构·算法·leetcode
爱编程的化学家16 小时前
代码随想录算法训练营第十一天--二叉树2 || 226.翻转二叉树 / 101.对称二叉树 / 104.二叉树的最大深度 / 111.二叉树的最小深度
数据结构·c++·算法·leetcode·二叉树·代码随想录
吃着火锅x唱着歌17 小时前
LeetCode 1446.连续字符
算法·leetcode·职场和发展
愚润求学17 小时前
【贪心算法】day10
c++·算法·leetcode·贪心算法
Tisfy18 小时前
LeetCode 0966.元音拼写检查器:三个哈希表实现
leetcode·字符串·散列表·题解·哈希表
ゞ 正在缓冲99%…18 小时前
leetcode35.搜索插入位置
java·算法·leetcode·二分查找
YuTaoShao19 小时前
【LeetCode 每日一题】36. 有效的数独
linux·算法·leetcode