분류 전체보기 74

[백준] 2225 합분해 - 골드 5

[오늘의 문제]https://www.acmicpc.net/problem/2225[오늘의 학습 키워드]DP구현1. 문제설명 N개의 정수가 주어질 때 N개의 정수중 K개를 이용하여 합이 N이 되는 경우의 수를 구하는 문제 입니다. 예를들어 20 2 가 주어진다면 0부터 20까지의 숫자중 2개를 사용하여 20을 만드는 경우의 수를 찾는 문제입니다. 같은 숫자를 여러번 사용해도 되고 덧셈의 순서가 바뀐다면 다른 경우로 셉니다. 즉 0 + 20 과 20 + 0 은 다른 경우의 수라는 것을 의미합니다.[제한사항]시간 제한 2초메모리 제한 128MB1 ≤ N ≤ 2001 ≤ K ≤ 2002. 접근방식 이번 문제는 점화식을 세우기 위해 N과 K의 관계를 잘 살펴보아야 합니다. 위 그림에서 N이 어떤 수가 오던간에 K가..

알고리즘 2025.05.26

[백준] 2293 동전 1 -골드 4

[오늘의 문제]https://www.acmicpc.net/problem/2293[오늘의 학습 키워드]DP구현1. 문제설명 N 가지 동전이 주어지고 만드려는 동전의 합 K가 주어질 때 동전의 합 K를 만드는 경우의 수를 출력하는 문제 입니다. 주어진 동전은 여러번 사용해도 합이 K원 되면 상관없고, 주어진 동전을 사용한 개수가 동일한데 순서가 다른 경우 이 경우는 동일한 경우로 생각합니다.[제한사항]시간 제한 0.5초메모리 제한 4MB1 ≤ N ≤ 100, 1 ≤ K ≤ 10,000 동전의 가치는 100,000보다 작거나 같은 자연수이다. 2. 접근방식 지난 시간 풀었던 동전 2 문제와 굉장히 유사한 문제 입니다. 동전 2의 경우 주어진 경우의 수 중에서 더 적은 동전을 사용하는 경우를 골라 DP에 누적시..

알고리즘 2025.05.25

[백준] 1699 제곱수의 합 - 실버 2

[오늘의 문제]https://www.acmicpc.net/problem/1699[오늘의 학습 키워드]DP구현1. 문제설명 자연수 N이 주어질 때 이 N을 만들 수 있는 제곱수의 합 중 최소의 개수를 구하는 프로그램을 작성하는 문제 입니다. 예를들어 자연수 7이 주어진 경우 7을 만들 수 있는 제곱수의 합은 2^2 + 1^2 + 1^2 + 1^2 = 7 이죠 다른 방법으로는 1^2을 7번 더해주는 방법도 존재합니다. 그러나 주어진 문제에서 항의 최소개수를 구하라 하였으니 1^2 3번 2^2 1번이 올바른 정답 이겠죠 [제한사항]시간 제한 2초메모리 제한 128MB1 ≤ N ≤ 100,0002. 접근방식 우선 자연수 N의 범위가 10만입니다. 섣부르게 중첩 반복문을 사용하면 반드시 시간초과가 발생하겠죠 이번..

알고리즘 2025.05.24

[백준] 11052 카드 구매하기 - 실버 1

[오늘의 문제]https://www.acmicpc.net/problem/11052[오늘의 학습 키워드]DP, 구현1. 문제설명문제가 길어서 복잡해 보이지만 쉽게 요약하면 구매하려는 카드의 개수 N이 주어질 때 카드 가격별로 가장 비싸게 카드를 구매하는 방법을 작성하는 프로그램을 구현하는 문제 입니다. 1 5 6 7은 각 카드별 금액으로 카드 1장 구매하는데는 1원카드 2장 구매하는데는 5원카드 3장 구매하는데는 6원카드 4장 구매하는데는 7원 입니다. 각각의 금액별로 패키징 된 카드들이고 여기서 가장 카드를 비싸게 사는 방법은 2장짜리 카드를 2번 사는 경우의 수 입니다.[제한사항]시간 제한 1초메모리 제한 256MB1 ≤ N ≤ 1,0001 ≤ Pi ≤ 10,0002. 접근방식 이 문제는 N장의 카드를..

알고리즘 2025.05.24

[백준] 2294 동전 2 - 골드 5

[오늘의 문제]https://www.acmicpc.net/problem/2294[오늘의 학습 키워드]DP, 구현1. 문제설명 N개의 동전으로 K원을 만들어야 하는데 동전을 최소한의 개수로 완성하는 프로그램을 작성하는 문제 입니다.[제한사항]시간 제한 1초메모리 제한 128MB1 ≤ n ≤ 100 1 ≤ k ≤ 10,000동전의 가치는 100,000보다 작거나 같은 자연수이다.2. 접근방식이번 문제는 고민을 많이 했던 문제 입니다. 예전에 한번 풀었던 문제 인데도 방법이 잘 생각나지 않았습니다. 우선 주어진 예시를 토대로 최소한의 코인을 구하는 과정을 전체 로직을 통해 생각해 보았습니다. 주어진 코인의 종류를 통해서 목표 금액이 15원을 만드는 방법을 전체 생각해 보았습니다. 1원의 경우 목표 금액 15원..

알고리즘 2025.05.21

[백준] 1912 연속합 - 실버 2

[오늘의 문제]https://www.acmicpc.net/problem/1912[오늘의 학습 키워드]DP, 구현1. 문제설명 N개의 정수로 이루어진 수열에서 연속해서 수들의 합을 구할 때 가장 큰 수를 구하는 방법을 작성하는 문제 입니다.[제한사항]시간 제한 1초메모리 제한 128MB1 ≤ n ≤ 100,000주어지는 수는 -1,000보다 크거나 같고, 1,000보다 작거나 같은 정수2. 접근방식 이번 문제는 쉽게 생각하면 해결이 되는 문제입니다. 수들은 음수 또는 양수로 주어집니다. -1000 부터 1000 사이의 수가 주어지니 0도 주어지겠죠 수열이 주어지면 DP 테이블을 만들고 DP 테이블에 이전 값들의 합과 현재값을 비교하는 겁니다. 그 두 수중 더 큰값으로 DP 테이블을 바꿔가면 DP 테이블을 ..

알고리즘 2025.05.20

[백준] 11053 가장 긴 증가하는 부분 수열 - 실버 3

[오늘의 문제]https://www.acmicpc.net/problem/11053[오늘의 학습 키워드]DP, 브루트포스 탐색, 구현1. 문제설명 수열이 주어질 때 해당 수열중에서 가장 긴 증가하는 부분 수열을 찾는 문제 입니다. 만약 1 2 1 2 3 이 주어진다면 이 수열의 길이는 3이 되겠죠 또 1 10 2 3 이 주어진다면 이 수열의 길이는 3이 됩니다. 이런식으로 주어진 수열 중에서 가장 긴 증가하는 부분을 찾는 문제 입니다.[제한사항]시간 제한 1초메모리 제한 256MB첫째 줄에 수열 A의 크기 N (1 ≤ N ≤ 1,000)이 주어진다.둘째 줄에는 수열 A를 이루고 있는 Ai가 주어진다. (1 ≤ Ai ≤ 1,000)2. 접근방식처음에는 문제의 예시만 보고 DP 테이블을 구성하기 위해 시간 복..

알고리즘 2025.05.19

[백준] 2193 이친수 - 실버 3

[오늘의 문제]https://www.acmicpc.net/problem/2193[오늘의 학습 키워드]DP, 구현1. 문제설명[제한사항]시간 제한 2초메모리 제한 128MB1 ≤ N ≤ 902. 접근방식이 문제는 0과 1로 이루어진 이친수를 구성하는 방식을 잘 생각해야 하는 문제입니다. 이친수는 1로만 시작하고 1이 연속할 수 없다는 특징이 있습니다. 그렇다면 이친수가 가능한 조건은 1로 시작한 수 중에서 1이 연속하지 않는다면 모두 이친수가 된다는 의미이죠 N 이 1이 주어졌다면 이친수가 될 수 있는 수는 1 뿐이고2가 주어진다면 103이 주어진다면 100, 1014가 주어진다면 1000, 1001, 1010 이런식으로 되겠죠 여기서 구할 수 있는 점화식은 0과 1의 개수를 다르게 보아야 한다는 것입니다..

알고리즘 2025.05.18

[백준] 1520 내리막 길 - 골드 3

[오늘의 문제]https://www.acmicpc.net/problem/1520[오늘의 학습 키워드]DP, DFS, 구현1. 문제설명 지난 시간 해결한 문제와 비슷한 문제 입니다. 지도 안에서 목적지에 도착 가능한 경로를 찾는 문제인데 이동은 4방향으로 이동이 가능하고, 반드시 내리막길로만 가려고 합니다. 목적지에 도착한 경우 그 경로의 개수를 출력하는 프로그램을 작성해야 합니다.[제한사항]시간 제한 2초메모리 제한 128MBM과 N은 각각 500이하의 자연수각 지점의 높이는 10000이하의 자연수2. 접근방식1890 점프 문제를 해결할 때 사용한 방식과 비슷하게 접근해 보았습니다. 현재 위치를 기준으로 다음 이동 가능 경로를 탐색하는데 4방향 중 지도를 벗어나지 않고, 내리막 길 인 경우 DP 테이..

알고리즘 2025.05.17

[백준]1890 점프 - 실버1

[오늘의 문제] https://www.acmicpc.net/problem/1890[오늘의 학습 키워드]DP, 구현1. 문제설명 N x N 크기의 미로에서 0, 0 위치에서 시작해 N, N 위치로 이동하는 경로의 수를 구하는 문제 입니다. 이동은 반드시 오른쪽 혹은 아래쪽으로만 가능하며 현재 도착한 칸에 이동 가능한 칸의 개수가 적혀 있습니다. 예를들어42 3 3 11 2 1 31 2 3 13 1 1 0 이렇게 미로가 주어진 경우 0, 0 위치에서 다음 이동 가능한 위치는 2칸 이동해서 0, 2 혹은 2, 0 이겠죠 이런식으로 N, N 위치까지 이동할 때 발생가능한 경로의 수를 모두 구하는 문제 입니다.[제한사항]시간 제한 1초메모리 제한 128MB4 ≤ N ≤ 100칸에 적혀있는 수는 0보다 크거나 같고..

알고리즘 2025.05.16