728x90
반응형
https://school.programmers.co.kr/learn/courses/30/lessons/181188
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
1. 미사일을 e를 기준으로 오름차순으로 정렬한다.
- 이미 요격된 미사일을 고려하기 위해 가장 짧은 미사일부터 요격을 시작한다.
2. 요격을 할 때마다 요격한 지점의 위치를 저장한다. 시작은 0
3. 미사일의 s가 요격 지점보다 크면, 미사일의 s 지점에 요격을 가한다.
- s지점을 요격 지점으로 새로 할당한다.
- 매번 요격한 미사일의 s지점을 요격 지점으로 정하기 때문에, 이보다 작은 요격 지점은 존재하지 않는다.
요격한 미사일의 끝 지점(e)를 요격 지점으로 계속 초기화
#include <vector>
#include <algorithm>
using namespace std;
struct Cmp
{
bool operator()(vector<int>& a, vector<int>& b) { return a[1] < b[1]; }
};
int solution(vector<vector<int>> targets) {
int answer = 0, Shot = 0;
sort(targets.begin(), targets.end(), Cmp());
for (const auto& target : targets)
{
if (target[0] < Shot) continue;
Shot = target[1];
answer++;
}
return answer;
}
728x90
반응형
'📕알고리즘 문제 > 📝Programmers' 카테고리의 다른 글
[프로그래머스] Level 2 : 프로세스 (0) | 2024.11.20 |
---|---|
[프로그래머스] Level 3 : 디스크 컨트롤러 (0) | 2024.11.18 |
[프로그래머스] Level 2 : 최댓값과 최솟값 (0) | 2024.11.11 |
[프로그래머스] Level 3 : 거스름돈 (0) | 2024.09.20 |
[프로그래머스] Level 2 : 카카오프렌즈 컬러링북 (0) | 2024.09.13 |