Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
Tags
- 스프링 부트와 AWS로 혼자 구현하는 웹 서비스
- 프로세스
- 빌드관리도구
- 알고리즘 1000000007 나누기
- 이코테2021
- Spring Security 버전 문제
- build.gradle 설정 오류
- 모듈로 연산
- 백트래킹
- Python 1000000007
- 기사단원의 무기 제곱근
- 달리기 경주 파이썬
- 정규화 장단점
- commit message convention
- RDBMS와 NoSQL 차이
- OOP의 특징
- 기사단원의 무기 파이썬
- 웹 동작 과정
- Spring Security 5
- MySQL RIGHT()
- @RequestMapping과 @GetMapping
- 빌드관리도구 차이
- DDL DML DCL 차이
- MySQL LEFT()
- java 동기화
- 프로그래머스 142086
- www.google.com 검색하면 일어나는 일
- 달리기 경주 파이썬 시간초과
- finalize 수동 호출
- PCB
Archives
- Today
- Total
BUILD_SSO
[프로그래머스] 달리기 경주 Python 풀이(시간초과 해결, dictionary 사용) 본문
Problem Solving/Algorithm
[프로그래머스] 달리기 경주 Python 풀이(시간초과 해결, dictionary 사용)
sohyeonnn 2023. 6. 14. 15:24문제링크: https://school.programmers.co.kr/learn/courses/30/lessons/178871
예제 입력:
players = ["mumu", "soe", "poe", "kai", "mine"]
callings = ["kai", "kai", "mine", "mine"]
예제 출력:
result = ["mumu", "kai", "mine", "soe", "poe"]
풀이
해설진은 선수들이 자기 바로 앞의 선수를 추월할때 추월한 선수의 이름을 부른다. 결기가 끝난 후 선수들의 이름이 불려진 순서를 1등부터 순서대로 배열에 담아 return하는 문제이다.
간단하다고 생각하고 풀었더니 또 시간초과에서 터졌다^^...
처음 작성한 코드:
def solution(players, callings):
for call in callings:
a = players.index(call) #이름이 불리는 선수의 players의 위치
players[a], players[a-1] = players[a-1], players[a]
return players
처음 작성한 코드에서는 callings 배열에서 이름이 불린 선수를 찾기 위해 .index()를 사용했다. 시간 초과된 후 생각해 보니 이렇게 하면 시간 복잡도가 O(n)이므로, 선수가 많고 경기가 길어질수록 효율성이 떨어질 수 있겠다는 생각이 들었다.
즉, 인덱스를 빠르게 찾을 수 있는 자료구조를 사용해야 하고 dictionary가 그 해답이다. 이름이 불린 선수의 위치를 빠르게 찾고, 해당 선수와 그 앞의 선수의 위치를 바꾸면 된다(이 로직은 똑같다).
dictionary를 사용하면 각 호출마다 시간 복잡도가 O(1)이 되기 때문에 훨씬 효율적으로 해결된다.
정답 코드:
def solution(players, callings):
player_dict = {player: idx for idx, player in enumerate(players)}
for call in callings:
idx = player_dict[call]
players[idx], players[idx-1] = players[idx-1], players[idx]
player_dict[players[idx]] = idx
player_dict[players[idx-1]] = idx-1
return players
해결했다! 조금 더 효율성에 유의하며 푸는 습관을 길러야겠다.
'Problem Solving > Algorithm' 카테고리의 다른 글
[프로그래머스] 기사단원의 무기 Python 풀이(제곱근 이용) (0) | 2023.06.03 |
---|---|
[프로그래머스] 142086 가장 가까운 같은 글자 python (0) | 2023.05.11 |
[백준] 15649 N과 M(1) python - DFS, 백트래킹 (0) | 2023.03.25 |
[백준] 14889 스타트와 링크 python - 백트래킹, 조합 (0) | 2023.03.24 |
[백준] 14888 연산자 우선순위 python - 구현, 백트래킹 (0) | 2023.03.22 |
Comments