일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 컨테이너실행
- 2 > /dev/null
- 커밋메세지수정
- appspec
- 검색
- 적용우선순위
- ㅔㄴ션
- appspec.yml
- 테스트메소드
- AuthenticationEntryPoint
- subquery
- 추후정리
- Query
- ubuntu
- WeNews
- foreignkey
- 참조키
- 포트
- 외부키
- application.yml
- 예약
- 서브쿼리
- EC2
- 메소드명
- docker명령어
- 메세지수정
- querydsl
- 테스트
- 네이티브쿼리
- MySQL
Archives
- Today
- Total
제뉴어리의 모든것
동적계획법 - 프로그래머스 코딩테스트 연습 본문
문제
숫자 5와 사칙연산만으로 12를 표현할 수 있다.
- 12 = 5 + 5 + (5 / 5) + (5 / 5)
- 12 = 55 / 5 + 5 / 5
- 12 = (55 + 5) / 5
5를 사용한 횟수는 각각 6,5,4 이고, 이중 가장 작은 경우는 4이다.
숫자 N과 number가 주어질 때 N과 사측연산만으로 number를 표현하는 방법 중 N의 최소사용횟수를 반환하라.
제한사항
- 1 <= N <= 9
- 1 <= number <= 32000
- 나누기 연산에서 나머지는 무시하기
- 최솟값이 8보다 크면 -1을 반환
문제풀이
- N의 최소 사용횟수가 8번보다 크면 -1을 반환하도록 제한되어있으므로 N을 1번 사용하는 것에서부터 8번사용하는 것까지를 순차적으로 숫자를 만들어보고, 1번부터 8번 집합에 각각 저장합니다. 그리고 number가 만들어졌는지 확인하면 됩니다.
- N이 5일때 5는 N을 1번 사용한 것이고, 55는 2번, 555는 3번, 5555는 4번, 55555555는 8번 사용한 것 입니다. 이를 각각의 집합에 미리 추가해줍니다.
- 1번 집합에 들어갈 수 있는 숫자는 5 하나 밖에 없습니다. 2번 집합에는 55외에 들어갈 수 있는 숫자가 있습니다. N + N, N-N, N*N, N/N. 즉, 1번 집합의 구성요소로 사측연산을 한 것입니다.
- 3번 집합의 구성은 555와 ( 1번집합의 구성요소 +-*/ 2번집합의 구성요소), ( 2번집합의 구성요소 +-*/ 1번집합의 구성요소) 입니다.
- 4번 집합의 구성은 5555와 ( 1번집합의 구성요소 +-*/ 3번집합의 구성요소), ( 2번집합의 구성요소 +-*/ 2번집합의 구성요소), ( 3번집합의 구성요소 +-*/ 1번집합의 구성요소) 입니다.
- 만들어진 숫자 중 타겟인 number이 발견되면 바로 집합 번호를 반환하면 됩니다.
- 순회가 모두 끝난 후에도 number를 발견하지 못했다면, 최소횟수가 8이상인 것이므로 -1를 반환합니다.
function solution(N, number) {
const s = [new Set()]
for (let i = 1; i <= 8; i++) {
s.push(new Set([new Array(i).fill(N).join('') * 1]))
for (let j = 1; j <= i; j++) {
for (const x1 of [...s[j]]) {
for (const x2 of [...s[i-j]]) {
s[i].add(x1 + x2)
s[i].add(x1 - x2)
s[i].add(x1 * x2)
if (x2) {
s[i].add((x1 / x2) - (x1 / x2) % 1)
}
}
}
}
if (s[i].has(number)) {
return i
}
}
return -1
}
시간복잡도: O(8 * 8 * 4 * 8) = O(1)
공간복잡도: O(1)
해당 풀이에서 영감 받은것은 사용횟수가 어차피 8번을 넘어가면 -1 이므로 1~7번 사용한 방법중에서 고르면 된다는점.
그리고 N을 더 많이 사용한 수식은 결국 적게 사용한 수식으로 만들어진다는점. (5번 사용한 수식은, 4번 [사칙연산] 1번
그리고 3번 [사칙연산] 2번... 이런식으로 규칙이 있다는것.
문제에서 보여준 예를 잘 읽고 왜 이런 예를 보여주였는가 고민하고 규칙을 찾아낼것
출처: https://allo-ew.tistory.com/118 [hon9g]
'알고리즘' 카테고리의 다른 글
프로그래머스 - 코딩테스트 연습 : 힙/더 맵게 (0) | 2021.04.03 |
---|---|
프로그래머스 - 코딩테스트 연습 : 스택/큐 다리를 지나는 트럭 (0) | 2021.04.02 |
알고리즘 해결 기법 (0) | 2021.01.20 |
동적계획법 (0) | 2021.01.09 |
프로그래머스 - 코딩테스트 /스택큐/기능개발 [Kotlin] (0) | 2021.01.07 |