일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- Prettier
- Notion to Github Markdown
- ESLint
- 코딩테스트
- CONVERTER
- 현파랑
- spring-mvc
- IT-Note
- 패스트캠퍼스
- BFS
- 개발상식
- 동적계획법
- 1003
- notion
- js
- spring
- 발자취
- 백준
- 알고리즘
- 면접
- webpack
- java
- react
- 다이나믹프로그래밍
- 완전탐색
- DFS
- 접근법
- 프로그래멋
- vsCode
- dp
Archives
- Today
- Total
두 번째 뇌
[ JS ] 1010번 다리 놓기 본문
개요
백준 1010번 문제입니다.
문제
https://www.acmicpc.net/problem/1010
접근법
주어진 그림이 어려울 수 있는데, 직접 점과 선으로 연결해보면 이 형태가 파스칼 삼각형을 이루는 것을 알 수 있습니다. 그에 맞춰 구현합니다.
코드
🤩 : DP
/**
* 입력
*/
// const fs = require('fs');
// const os = require('os');
// const input = fs.readFileSync('dev/stdin').toString().trim().split(os.EOL);
// const cases = input.slice(1).map(e => {
// return e.split(' ').map(e2 => Number(e2));
// });
/**
* Solve 함수
*/
const solution = cases => {
const dp = Array.from({ length: 30 }, () =>
Array.from({ length: 30 }, () => 0),
);
for (let i = 1; i < 30; i++) {
for (let j = 1; j < 30; j++) {
if (i === 1) {
dp[i][j] = j;
} else if (i === j) {
dp[i][j] = 1;
} else if (j > i) {
dp[i][j] = dp[i - 1][j - 1] + dp[i][j - 1];
}
}
}
for (const [N, M] of cases) {
console.log(dp[N][M]);
}
};
// solution(cases);
/**
* ========================================================
* @Title : 1010
* @Path : javascript\문제풀이\boj\z.분류없음\1010_다리놓기.spec.js
* @Link : https://www.acmicpc.net/problem/1010
* @Description : 다리 놓기
* @Note : 1. I/O 신경 쓰지 말고 solution() 함수만 잘 작성하자
* : 파스칼 삼각형
* @Date : 2021-08-20 12:45:14
* --------------------------------------------------------
* @Author : Inseong-so(https://github.com/inseong-so)
* ========================================================
*/
describe('1010_다리놓기', () => {
// 테스트 케이스명
it('기본1', () => {
console.log = jest.fn();
// 변수 입력하기
const input = [
[2, 2],
[1, 5],
[13, 29],
];
// 함수 실행
solution(input);
// 결과
const result = [1, 5, 67863915];
// 테스트 결과 정의
expect(console.log).toHaveBeenCalledWith(result);
});
});
'개발자 지식 > Algorithm' 카테고리의 다른 글
[ Python ] 1003번 피보나치 함수 (0) | 2021.08.01 |
---|---|
[ Python ] BOJ 단계별 풀어보기 - 동적계획법 1 (0) | 2021.07.31 |
[ Python ] BOJ 단계별 풀어보기 - 문자열 (0) | 2021.07.31 |
[JS] DFS : 거리 두기 확인하기(2021 카카오 인턴십) (0) | 2021.07.09 |
[JS] 투 포인터(Two-Pointers) : 연속 부분수열 (0) | 2021.07.04 |
Comments