สมมติว่าเรามีอาร์เรย์ของเหตุการณ์ที่ events[i] =[startDayi, endDayi] ที่นี่ทุกงานที่ฉันเริ่มต้นที่ startDayi และสิ้นสุดที่ endDayi เราสามารถเข้าร่วมกิจกรรม I ได้ทุกวัน d โดยที่ d อยู่ในช่วง startTimei และ endTimei (รวมทั้งสองอย่าง) เราต้องจำไว้ว่าเราสามารถเข้าร่วมได้ครั้งละหนึ่งงานเท่านั้น ดังนั้นจงหาจำนวนกิจกรรมสูงสุดที่เราสามารถเข้าร่วมได้ ตัวอย่างเช่น หากอินพุตเป็น [[1,4], [4,4], [2,2], [3,4], [1,1]] ผลลัพธ์จะเป็น 1 ตามที่เรา สามารถเข้าร่วมได้สูงสุด 4 กิจกรรม ได้แก่ [1, 1], [2, 2], [3, 4] และ [4, 4]
เพื่อแก้ปัญหานี้ เราจะทำตามขั้นตอนเหล่านี้ -
-
n :=จำนวนเหตุการณ์ จากนั้นเรียงลำดับรายการเหตุการณ์ตามวันที่เริ่มต้น ตั้งค่า ret :=0 และ itr :=0
-
สร้างคิวลำดับความสำคัญตาม max-heap ที่เรียกว่า pq
-
สำหรับผมอยู่ในช่วง 1 ถึง 10,000
-
ในขณะที่ itr
-
แทรกเหตุการณ์[itr, 1]
-
เพิ่มขึ้นอีก 1
-
-
ในขณะที่ pq ไม่ว่างและด้านบนของ pq
-
ลบองค์ประกอบออกจาก pq
-
-
ถ้า pq ไม่ว่าง ให้ลบออกจาก pq และเพิ่ม ret ขึ้น 1
-
-
รีเทิร์น
ตัวอย่าง (C++)
ให้เราดูการใช้งานต่อไปนี้เพื่อความเข้าใจที่ดีขึ้น -
#include <bits/stdc++.h>
using namespace std;
class Solution {
public:
static bool cmp(vector <int>& a, vector <int>& b){
return a[0] < b[0];
}
int maxEvents(vector<vector<int>>& events) {
int n = events.size();
sort(events.begin(), events.end(), cmp);
int ret = 0;
int itr = 0;
priority_queue <int, vector <int>, greater <int>> pq;
for(int i = 1; i <= 1e5; i++){
while(itr < n && events[itr][0] == i){
pq.push(events[itr][1]);
itr++;
}
while(!pq.empty() && pq.top() < i) pq.pop();
if(!pq.empty()){
pq.pop();
ret++;
}
}
return ret;
}
};
main(){
vector<vector<int>> v = {{1,4},{4,4},{2,2},{3,4},{1,1}};
Solution ob;
cout << (ob.maxEvents(v));
} อินพุต
[[1,4],[4,4],[2,2],[3,4],[1,1]]
ผลลัพธ์
4