프린세스 다이어리

[LeetCode] Reverse String - 자바스크립트 풀이 본문

자료구조, 알고리즘

[LeetCode] Reverse String - 자바스크립트 풀이

개발공주 2021. 11. 29. 19:47
728x90

문자열 뒤집기 문제.

 

1. 접근 방법

(1) 문제가 재귀 알고리즘 분류 안에 있고 + 내가 재귀를 공부해야 하고 + 각 반복적인 연산으로 특정 조건에 다다를 때까지 수행하면 되기 때문에 재귀로 접근한다.

 

(2) 인덱스 양쪽 끝에서부터 원소를 교체해, 가운데 mid 지점으로 옮겨갈 때까지 재귀 수행

- 베이스 케이스: 왼쪽 인덱스가 가운데 인덱스보다 커지면 함수를 종료한다.

- 점화식: 두 인덱스에 해당하는 값끼리 교체해 준다. 그리고 인덱스를 하나씩 옮겨준다.

 

2. 전체 해답

/**
 * @param {character[]} s
 * @return {void} Do not return anything, modify s in-place instead.
 */
var reverseString = function(s) {
    let left = 0;
    let right = s.length - 1;
    let mid = Math.floor((left + right) / 2);
    
    const recursive = (arr) => {
        if (left > mid) return;
        
        let temp = arr[left];
        arr[left] = arr[right];
        arr[right] = temp;
        
        left++;
        right--;
        
        recursive(arr);
    }
    
    recursive(s);
    return s;
};
728x90
Comments