Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 큐
- RxJS
- cors
- 스택
- Machine Learning
- 이진탐색
- 웹팩
- 브라우저
- 포인터
- 배열
- 타입스크립트
- 알고리즘
- 연결리스트
- APOLLO
- alexnet
- C
- 자바스크립트
- 프로그래머스
- 코딩테스트
- GraphQL
- RT scheduling
- 해시테이블
- pytorch
- 자료구조
- 연결 리스트
- 컨테이너
- 프론트엔드
- vue3
- 릿코드
- 프로세스
Archives
- Today
- Total
프린세스 다이어리
[LeetCode] Reverse String - 자바스크립트 풀이 본문
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
'자료구조, 알고리즘' 카테고리의 다른 글
[LeetCode] Reverse Linked List - 자바스크립트 풀이 (0) | 2021.11.30 |
---|---|
[LeetCode] Swap Nodes in Pairs - 자바스크립트 풀이 (0) | 2021.11.30 |
[LeetCode] Valid Perfect Square - 자바스크립트 풀이 (0) | 2021.11.29 |
[LeetCode] Pow(x, n) 문제 - 자바스크립트 풀이 (0) | 2021.11.29 |
[LeetCode] Find K Closest Elements - 자바스크립트 풀이 (0) | 2021.11.28 |
Comments