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
- GraphQL
- 웹팩
- Machine Learning
- 코딩테스트
- APOLLO
- 프로그래머스
- 이진탐색
- 배열
- cors
- 타입스크립트
- RT scheduling
- pytorch
- alexnet
- 연결리스트
- C
- 자료구조
- 자바스크립트
- 브라우저
- 프로세스
- 프론트엔드
- 컨테이너
- 릿코드
- vue3
- 스택
- 포인터
- 큐
- 해시테이블
- 연결 리스트
Archives
- Today
- Total
프린세스 다이어리
[LeetCode] Pascal's Triangle II - 자바스크립트 풀이 본문
728x90
1. 접근 방법
(1) 구하고자 하는 rowIndex의 각 원소의 값을 구하려면 이전 rowIndex의 각 원소의 값이 필요하기 때문에 통째로 삼각형을 만들어주면 된다.
(2) n번째 줄의 각 원소는 다음과 같이 구성돼 있다. 인덱스 0은 1, 인덱스 1~n-1는 n-1번째 줄의 인접한 왼쪽, 오른쪽 원소를 더한 값, 인덱스 n은 1이다.
(3) (2)번의 내용을 이중 for문을 이용해 만들어준다.
row.push(1);
for (let i = 1; i <= rowIndex; i++) {
// 이전 row의 길이보다 1 작은 숫자 만큼 for문을 돈다. 맨 마지막은 1임.
for (let j = row.length - 1; j > 0; j--) {
row[j] = row[j - 1] + row[j];
}
// 맨 마지막은 직접 넣어준다. i = 1인 경우 j for문은 타지 않음.
row.push(1);
}
(4) 중첩된 j for문에서 j를 거꾸로 감소시키는 이유는 j for문에서 하나씩 업데이트되는 숫자와 다음 턴을 돌 때의 숫자가 서로 영향을 미치지 않게 하기 위해서다.
자기 자신 + 자기 자신의 이전 인덱스를 더하는데 오름차순으로 연산을 하면 row = [1, 3, 3, 1]이 아니라, row = [1, 3, 4, 1]이 될 것이다.
2. 전체 해답
/**
* @param {number} rowIndex
* @return {number[]}
*/
var getRow = function(rowIndex) {
let row = [];
row.push(1); // [1]
for (let i = 1; i <= rowIndex; i++) {
// 이전 row의 길이보다 1 작은 숫자 만큼 for문을 돈다. 맨 마지막은 1임.
for (let j = row.length - 1; j > 0; j--) {
row[j] = row[j - 1] + row[j];
}
// 맨 마지막은 직접 넣어준다. i = 1인 경우 j for문은 타지 않음.
row.push(1);
}
return row;
};
728x90
'자료구조, 알고리즘' 카테고리의 다른 글
[LeetCode] Climbing Stairs - 자바스크립트 풀이 (0) | 2021.12.06 |
---|---|
[LeetCode] Fibonacci Number - 자바스크립트 풀이 (0) | 2021.12.05 |
[LeetCode] Search in a Binary Search Tree - 자바스크립트 풀이 (0) | 2021.11.30 |
[LeetCode] Reverse Linked List - 자바스크립트 풀이 (0) | 2021.11.30 |
[LeetCode] Swap Nodes in Pairs - 자바스크립트 풀이 (0) | 2021.11.30 |
Comments