일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- Typescript
- 알고리즘
- 프로그래머스 JS
- Next.js
- 정렬
- 코딩테스트
- React
- 자바
- 네트워크
- js
- 그리디
- Python
- 프로그래머스
- CSS
- bfs/dfs
- CLASS
- programmers
- 연습문제
- Baekjoon
- 이것이 코딩테스트다 with 파이썬
- SWEA
- 백준
- Lv2
- 자바스크립트
- Java
- greedy
- Lv1
- javascript
- node.js
- 코딩테스트 입문
Archives
- Today
- Total
개발야옹
[Programmers] 탐욕법 Greedy - lv3 단속카메라 본문
단속카메라
문제 설명
고속도로를 이동하는 모든 차량이 고속도로를 이용하면서 단속용 카메라를 한 번은 만나도록 카메라를 설치하려고 합니다.
고속도로를 이동하는 차량의 경로 routes가 매개변수로 주어질 때, 모든 차량이 한 번은 단속용 카메라를 만나도록 하려면 최소 몇 대의 카메라를 설치해야 하는지를 return 하도록 solution 함수를 완성하세요.
제한 사항
- 차량의 대수는 1대 이상 10,000대 이하입니다.
- routes에는 차량의 이동 경로가 포함되어 있으며 routes[i][0]에는 i번째 차량이 고속도로에 진입한 지점, routes[i][1]에는 i번째 차량이 고속도로에서 나간 지점이 적혀 있습니다.
- 차량의 진입/진출 지점에 카메라가 설치되어 있어도 카메라를 만난것으로 간주합니다.
- 차량의 진입 지점, 진출 지점은 -30,000 이상 30,000 이하입니다.
입출력 예
-5 지점에 카메라를 설치하면 두 번째, 네 번째 차량이 카메라를 만납니다.
-15 지점에 카메라를 설치하면 첫 번째, 세 번째 차량이 카메라를 만납니다.
풀이 코드
def solution(routes):
answer = 0
routes.sort(key=lambda x: x[0])
camera = -30001
for s, e in routes:
print(s, e, camera, answer)
if s > camera:
camera = e
answer += 1
camera = min(camera, e)
return answer
728x90
'Algorithm\CodingTest > Programmers' 카테고리의 다른 글
[Programmers] BFS/DFS - lv2 타겟넘버 (0) | 2024.09.08 |
---|---|
[Programmers:SQL] SELECT -lv1 특정 형질을 가지는 대장균 찾기 (1) | 2024.09.08 |
[Programmers] 탐욕법 Greedy - lv2 구명보트 (0) | 2024.09.08 |
[Programmers] 탐욕법 Greedy - lv2 조이스틱 (0) | 2024.09.07 |
[Programmers] Summer/Winter Coding(~2018) - 점프와 순간 이동 lv2 (1) | 2023.11.28 |