일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 메모이제이션
- 프로그래머스
- softeer
- Stack
- Python
- DP
- programmers
- 브루트포스
- 다이나믹프로그래밍
- 자바스크립트
- 깊이 우선 탐색
- group by
- 동적계획법
- binary search
- Lv. 3
- level3
- Lv. 1
- 너비 우선 탐색
- SQL 고득점 KIT
- C언어
- 소프티어
- Lv. 2
- javascript
- dfs
- 스택
- 파이썬
- Dynamic Programming
- Java
- bfs
- Lv. 0
- Today
- Total
목록2024/03/28 (2)
몸과 마음이 건전한 SW 개발자
문제 링크 https://school.programmers.co.kr/learn/courses/30/lessons/250136 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 정답 코드 function solution(land) { const [n, m] = [land.length, land[0].length]; const dr = [-1, 1, 0, 0]; const dc = [0, 0, -1, 1]; const isValid = (nr, nc) => { return 0 { // 몇 번 열에서 석유를 뽑았는지 확인해줄 배열 let visited = Arr..
구현 // 최대공약수 const gcd = (n1, n2) => { // 일반적으로 n1이 크다고 전제하고 계산 if (n2 > n1) { [n1, n2] = [n2, n1]; }; // n2가 0이 될 때까지 진행 while (n2) { [n1, n2] = [n2, n1%n2]; }; return n1 }; // 단순 최소공배수 const simpleLcm = (n1, n2) => { for (let num = Math.max(n1, n2); num { // 최대공약수를 활용 return (n1 * n2) / gcd(n1, n2); }; console.log(uclidLcm(123, 456)); // 18696 console.log(simpleLcm(123, 456)); // 18696