Notice
Recent Posts
Recent Comments
«   2025/05   »
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
Archives
Today
Total
관리 메뉴

Día de Ruru

20230518 TIL 본문

항해99/TIL

20230518 TIL

공대루루 2023. 5. 18. 22:57

코딩테스트 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