한 개의 회의실이 있는데 이를 사용하고자 하는 n개의 회의들에 대하여 회의실 사용표를 만들려고 한다. 각 회의에 대해 시작시간과 끝나는 시간이 주어져 있고, 각 회의가 겹치지 않게 하면서 회의실을 사용할 수 있는 최대수의 회의를 찾아라. 단, 회의는 한번 시작하면 중간에 중단될 수 없으며 한 회의가 끝나는 것과 동시에 다음 회의가 시작될 수 있다.
Input1 | Output |
---|---|
[ [1, 4], [2, 3], [3, 5], [4, 6], [5, 7] ] | 3 |
(2, 3), (3, 5), (5, 7)이 회의실을 이용할 수 있다.
const solution = (conf) => {
let answer = 0;
conf.sort((a,b) => {
if(a[1] === b[1]) return a[0] - b[0];
else return a[1] - b[1];
});
let et = 0;
for (let x of conf) {
if(x[0] >= et) {
answer++;
et = x[1];
}
}
return answer;
};