1.タイトル
MyCalendarクラスを実装してスケジュールを保存すると、いつでも新しいスケジュールを追加できます。
MyCalendarにはbook(int start, int end)
メソッドがあります。これは、時間の終わりに開始するスケジュールを追加することを意味します。注意、ここでの時間は半開間隔です。つまり[start, end)
、xの範囲は実数start <= x < end
です。
K個のスケジュールに時間の重複がある場合(たとえば、K個のスケジュールがすべて同じ時間にある場合)、K個の予約が生成されます。
MyCalendar.book
メソッドが整数Kを返すときの各呼び出しは、最大のK回のブックを表します。
以下の手順に従って、MyCalendarクラスを呼び出します。 MyCalendar cal = new MyCalendar(); MyCalendar.book(start, end)
示例 1:
MyCalendarThree();
MyCalendarThree.book(10, 20); // returns 1
MyCalendarThree.book(50, 60); // returns 1
MyCalendarThree.book(10, 40); // returns 2
MyCalendarThree.book(5, 15); // returns 3
MyCalendarThree.book(5, 10); // returns 3
MyCalendarThree.book(25, 55); // returns 3
解释:
前两个日程安排可以预订并且不相交,所以最大的K次预订是1。
第三个日程安排[10,40]与第一个日程安排相交,最高的K次预订为2。
其余的日程安排的最高K次预订仅为3。
请注意,最后一次日程安排可能会导致局部最高K次预订为2,但答案仍然是3,
原因是从开始到最后,时间[10,20],[10,40]和[5,15]仍然会导致3次预订。
说明:
每个测试用例,调用 MyCalendar.book 函数最多不超过 400次。
调用函数 MyCalendar.book(start, end)时,
start 和 end 的取值范围为 [0, 10^9]
出典:LeetCode(LeetCode)リンク:https://leetcode-cn.com/problems/my-calendar-iii
著作権はLeetCodeが所有しています。商用の再版については、公式の承認に連絡してください。非商用の再版については、出典を示してください。
2.問題解決
同様のトピック:
LeetCode 729.私のスケジュールI(バイナリ検索を設定)
LeetCode 731.私のスケジュールII(バイナリ検索/差分思考を設定)
- この問題のより良い解決策は、ラインセグメントツリーです(記述できません)。
- 違いの考え方で行う
class MyCalendarThree {
map<int,int> m;
public:
MyCalendarThree() {
}
int book(int start, int end) {
m[start]++;//差分思想
m[end]--;
int count = 0, maxCount = 0;
for(auto it = m.begin(); it != m.end(); ++it)
{
count += it->second;
maxCount = max(maxCount, count);
}
return maxCount;
}
};
364 ms 24.2 MB
私のCSDNブログアドレスhttps://michael.blog.csdn.net/
QRコードを長押しまたはスキャンして、私の公式アカウント(Michael Amin)をフォローし、一緒に来て、学び、一緒に進歩してください!