인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

문제훈님의 프로필 이미지
문제훈

작성한 질문수

자바스크립트 알고리즘 문제풀이 입문(코딩테스트 대비)

4. 문자거리

시간복잡도가 크게 올라갈까요??

작성

·

282

0

function solution(s, t) {
  let answer = [];
  let count = 0;

  for (let i = 0; i < s.length; i++) {
    if (s[i] === t) {
      count = 0;
      answer.push(count);
    } else {
      count++;
      answer.push(Math.min(count, s.slice(i).indexOf(t)));
    }
  }

  return answer.join(" ");
}

let str = "teachermode";
console.log(solution(str, "e"));

3-4 가장 짧은 문자거리를 이렇게 풀어보았는데요,

강사님이 풀이하신 것과 비교해서 시간복잡도가 크게 증가할까요??

답변 1

2

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

slice 메서드의 시간복잡도가 O(n) 입니다. 매 문자마다 i부터 s의 끝까지 반복한다고 봐야 합니다.

또 indexOf 도 O(n)복잡도 입니다. 위코드에서 slice로 복사된 부분을 모두 탐색한다고 봐야 합니다.

복잡도가 영상의 방법보다 많이 증가하는 코드입니다.

문제훈님의 프로필 이미지
문제훈

작성한 질문수

질문하기