알고리즘
그리디 알고리즘
엑츄얼리
2023. 2. 17. 15:01
지금 가장 최적인 답을 근시안적으로 택하는 알고리즘
= 관찰을 통해 탐색 범위를 줄이는 알고리즘
이상적인 풀이 흐름
- 관찰을 통해 탐색 범위를 줄이는 방법
- 탐색 범위를 줄여도 올바른 결과를 낸다는 사실을 수학적으로 증명 (실제 코테에서는 수학적 증명이 사실상 불가)
- 구현해서 문제를 통과
코딩 테스트에서의 추천 전략
- 거의 똑같은 문제를 풀어봤거나 간단한 문제여서 나의 그리디 풀이를 확신! ⇒ 짜서 제출해보고 틀리면 빠르게 손절
- 100%확신은 없지만 맞는 것 같은 그리드 풀이를 찾았다. ⇒ 일단은 넘어가고 다른 문제를 풀게 없거나 종료가 20-40분 남은 시점에 시작
⇒ 코테에 그렇게 잘 나오는 문제는 아니다.
11047 - 동전
1931 - 회의실배정
t 이후에 회의 A와 B를 선택하는 경우에서 회의 B를 선택했을 경우 (정답은 정해져있음 결국에는 회의 A도 선택하게되므로 지금 최선의 선택을 하지 않았을 경우 최선의 선택을 했을 때보다 더 결과가 좋아질 수 없음을 의미
- sort 순서에 따른 결과차이 (cmp2는 pair<int, int> cur의 cur.second에 의한 오름차순)
- 해당 문제에서 아래와 같은 코드도 결과1과 같은 결과를 얻을 수 있는데, 나중에 정렬강의 듣고 다시 생각해봐야겠다. (14:50)
그리디 같지만 아닌 문제들
12865, 1477 풀어보고 꼭 강의 보기!