Día de Ruru
20230518 TIL 본문
코딩테스트 1단계 달리기 경주
얀에서는 매년 달리기 경주가 열립니다. 해설진들은 선수들이 자기 바로 앞의 선수를 추월할 때 추월한 선수의 이름을 부릅니다. 예를 들어 1등부터 3등까지 "mumu", "soe", "poe" 선수들이 순서대로 달리고 있을 때, 해설진이 "soe"선수를 불렀다면 2등인 "soe" 선수가 1등인 "mumu" 선수를 추월했다는 것입니다. 즉 "soe" 선수가 1등, "mumu" 선수가 2등으로 바뀝니다.
선수들의 이름이 1등부터 현재 등수 순서대로 담긴 문자열 배열 players와 해설진이 부른 이름을 담은 문자열 배열 callings가 매개변수로 주어질 때, 경주가 끝났을 때 선수들의 이름을 1등부터 등수 순서대로 배열에 담아 return 하는 solution 함수를 완성해주세요.
players callings result ["mumu", "soe", "poe", "kai", "mine"] ["kai", "kai", "mine", "mine"] ["mumu", "kai", "mine", "soe", "poe"]
나의 풀이
나의 풀이는 시간복잡도에서 걸려서 실패가 도출되었다. 코드 자체만으로 봤을 때 시간복잡도가 높아보이지 않다고 생각했는데 for 구문 안에 들어있는 indexOf의 시간복잡도가 높아서 그런 것이었다.
function solution(players, callings) {
for (let i =0;i<callings.length;i ++){
let name = callings[i]
let index = players.indexOf(name) - 1
let name2 = players[index]
players[index] = name
players[index + 1] = name2
}
return players
}
indexOf는 배열의 처음부터 요소를 찾으면서 해당 요소의 index 값을 return 한다. 요소에 해당하는 index를 빨리 찾을 경우에는 시간이 짧게 걸리지만 최악의 경우에는 모든 배열을 다 돌고나서 index를 찾는 경우도 있을 것이다. 이때문에 indexOf의 시간복잡도는 기본적으로 O(n)이라고 한다.
내가 작성한 코드는 indexof 의 시간복잡도가 O(n)이니까 for 구문까지 하면 전체적으로는 O(n^2)의 시간복잡도가 나오게 된다....
테스트에 통과한 다른 사람 풀이
indeOf를 사용하지 않기 위해 아래처럼 미리 각 요소의 index를 넣어둔 객체의 배열을 만들어두고 그 배열의 값을 수정하는 방향으로 코드를 작성하면 된다.
function solution(players, callings) {
let answer = {};
// 객체에다가 players index 순서를 넣어준다
players.forEach((player,i) => answer[player] = i)
callings.forEach((player) => {
// currentUser calling으로 부르는 이름의 인덱스를 객체에서 가져온다.
// prevUser는 players에서 calling 부른 사람 전의 사람을 가져온다
const currentUser = answer[player];
const prevUser = players[currentUser-1]
// 배열에서 prevUser와 player의 자리를 바꿔준다.
players[currentUser] = prevUser;
players[currentUser-1] = player
// 객체에서 콜링으로 부른 사람은 -- 그전사람은 ++
answer[player] --;
answer[prevUser] ++;
})
return players
}
'항해99 > TIL' 카테고리의 다른 글
20230612 TIL (0) | 2023.06.13 |
---|---|
20230523 TIL (0) | 2023.05.24 |
20230509 TIL (0) | 2023.05.10 |
20230502 TIL (0) | 2023.05.03 |
20230419 TIL (0) | 2023.04.20 |
Comments