알고리즘
프로그래머스 요격시스템
minbear
2023. 7. 30. 16:34
#프로그래머스 요격시스템
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
#풀이
프로그래머스에는 익숙하지 않아서 입력 형태를 보고 조금 헷갈렸다. 나는 2차원벡터을 잘 사용하지 않을 뿐더러
2차원 벡터를 만들 때 vector<int> v[100]; 이런 형태로 만들어 사용한다. 그래서 그런가 벡터의 성질을 자주 까먹는다....
이 문제는 간단하다.
정렬을 해야 하는데 e의 오름차순으로 정렬을 해야 한다.
만약 s의 오름차순으로 정렬을 하면 [0,10000]이 가장 먼저 나와 문제를 해결할 수 없다.
정렬하는 방법은 여러가지가 있지만 stl sort() 함수는 시간복잡도(nlgn)을 보장하기 때문에 stl을 사용하는 것을 추천한다.
나는 cmp() 를 만들어 e로 비교하게 끔 만들어줬다.
그리고 cmp() 함수를 만들 때 항상 헷갈린다.
ture가 되면 누가 앞으로 가는지... 이제는 외워야 할 것 같은데 아직 안외워진다....ㅜㅜ
true를 반환하면 a가 앞으로 간다.
#코드
#include <string>
#include <vector>
#include <algorithm>
using namespace std;
bool cmp(vector<int> a, vector<int> b){
return a[1] < b[1];
}
int solution(vector<vector<int>> targets) {
int answer = 1;
sort(targets.begin(), targets.end(), cmp);
int lim_e = targets[0][1];
for(int i= 1; i < targets.size(); i++){
if(lim_e <= targets[i][0]){
lim_e = targets[i][1];
answer++;
}
}
return answer;
}