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 |
Tags
- BFSDFS
- scc
- CS Academy
- hashing
- graph modeling
- Cycle detecting
- Greedy
- dynamic programming
- Eulerian circuit
- disjoint-set
- POJ
- Euler path
- Euler circuit
- Segment Tree
- graph
- Eulerian path
- mathematics
- Dag
- bitmask
- 백준
- Sieve_of_Eratosthenes
- implementation
- GCD
- Shortest path
- flows
- DynamicProgramming
- backtracking
- BOJ
- Algospot
- BST
Archives
- Today
- Total
그냥 하는 노트와 메모장
BOJ 1955 수식 표현 본문
BOJ 1955 수식 표현
[분류 : 다이나믹 프로그래밍]
[풀이]
할 수 있는 연산을 생각해보자.
- 덧셈
- 곱셈
- 팩토리얼
여기 세 가지 연산에서 항으로 들어갈 수 있는 표현식도 생각해보자. 대신 마지막 표현식만 생각하자. 표현식을 e1, e2로 둘 때 e1+e2, e1*e2, e1!로 표현이 가능하다.
따라서 n이 주어지면 1.에서는 단순 덧셈으로 구간을 나누고, 2.에서는 약수 판별을, 3.에서는 현재 값이 특정 표현식 e1의 팩토리얼인지 확인해서 다이나믹을 구성해주면 된다. 특정 표현식이라고 표기한 이유는 6! = (3!)!일 수도, (1+5)!일 수도 있기 때문이다.
더보기
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std;
const int MAX_N = 1e4 + 1;
int main() {
int n, i, j, dp[MAX_N] = { 0, 1 }, fac[9] = { 1 }, sqrtn;
for (i = 1; i < 9; i++) fac[i] = fac[i - 1] * i;
scanf("%d", &n);
for (i = 2; i <= n; i++) {
int& ret = dp[i];
ret = i;
for (j = 1; j <= i / 2; j++)
ret = min(ret, dp[j] + dp[i - j]); // +
sqrtn = sqrt(i);
for (j = 2; j <= sqrtn; j++) if (i % j == 0)
ret = min(ret, dp[j] + dp[i / j]); // *
for (j = 2; j < 9; j++) if (i == fac[j]) // !
ret = min(ret, dp[j]);
}
printf("%d", dp[n]);
return 0;
}
'Solved problems' 카테고리의 다른 글
BOJ 10563 정수 게임 (0) | 2020.06.13 |
---|---|
BOJ 1555 소수 만들기 (0) | 2020.06.12 |
BOJ 15487 A[j]-A[i]+A[l]-A[k] (0) | 2020.06.11 |
BOJ 2313 보석 구매하기 (0) | 2020.06.11 |
BOJ 10468 숫자뽑기게임 (0) | 2020.06.09 |
Comments