본문 바로가기
  • 삽질하는 자의 블로그
CS와 언어, 라이브러리 이론/알고리즘-이론과 실전

3. [실전] - 가장 가까운 글자찾기

by 이게뭐당가 2023. 1. 18.

문제

문자열 s가 주어졌을 때, s의 각 위치마다 자신보다 앞에 나왔으면서, 
자신과 가장 가까운 곳에 있는 같은 글자가 어디 있는지 알고 싶습니다.
예를 들어, s="banana"라고 할 때,  각 글자들을 왼쪽부터 오른쪽으로 읽어 나가면서 
다음과 같이 진행할 수 있습니다.

    b는 처음 나왔기 때문에 자신의 앞에 같은 글자가 없습니다. 이는 -1로 표현합니다.
    a는 처음 나왔기 때문에 자신의 앞에 같은 글자가 없습니다. 이는 -1로 표현합니다.
    n은 처음 나왔기 때문에 자신의 앞에 같은 글자가 없습니다. 이는 -1로 표현합니다.
    a는 자신보다 두 칸 앞에 a가 있습니다. 이는 2로 표현합니다.
    n도 자신보다 두 칸 앞에 n이 있습니다. 이는 2로 표현합니다.
    a는 자신보다 두 칸, 네 칸 앞에 a가 있습니다. 이 중 가까운 것은 두 칸 앞이고, 이는 2로 표현합니다

    따라서 최종 결과물은 [-1, -1, -1, 2, 2, 2]가 됩니다.

 

 

프로세스

1. 범위를 0~1, 0~2, 0~3 을 지정해가며, 내 몇번 앞에 같은 것이 있나 찾는다.(slice, lastIndexOf)

사용

1. map(value,index)
2. slice(start,end)
3. lastIndexOf()

 

내코드

const solution = (s) =>
    [...s].map((char, i) => {
        const count = s.slice(0, i).lastIndexOf(char);
        return count < 0 ? count : i - count;
   });

 

댓글