본문 바로가기

반응형

PS

(326)
[BOJ] 백준 1932 정수 삼각형 (Swift) 문제 https://www.acmicpc.net/problem/1932 1932번: 정수 삼각형 첫째 줄에 삼각형의 크기 n(1 ≤ n ≤ 500)이 주어지고, 둘째 줄부터 n+1번째 줄까지 정수 삼각형이 주어진다. www.acmicpc.net 풀이 왼쪽 대각선 혹은 오른쪽 대각선으로 내려오면서 수들을 더해주고, 가장 큰 수를 구하는 문제입니다. 2차원 배열에 입력을 담아줍시다. 이 테두리에 있는 수들은 위에 수에서 내려올 수 있는 경로가 하나밖에 없습니다. 테두리에 있는 수는 x좌표가 0이거나, y좌표와 x좌표가 같은 경우입니다. x좌표가 0일 때는 (y - 1, x) 에서 내려오는 경로밖에 없습니다. y좌표와 x좌표가 같은 경우일 때는 (y - 1, x - 1) 에서 내려오는 경로밖에 없습니다. 하지..
[BOJ] 백준 1149 RGB거리 (Swift) 문제 https://www.acmicpc.net/problem/1149 1149번: RGB거리 첫째 줄에 집의 수 N(2 ≤ N ≤ 1,000)이 주어진다. 둘째 줄부터 N개의 줄에는 각 집을 빨강, 초록, 파랑으로 칠하는 비용이 1번 집부터 한 줄에 하나씩 주어진다. 집을 칠하는 비용은 1,000보다 작거나 www.acmicpc.net 풀이 이 문제의 규칙을 쉽게 설명하면 같은 색으로 연속되게 집을 색칠하지 않고 집을 모두 칠하는 비용의 최소 값을 구해라! 입니다. 1번 집을 빨강으로 칠했다면, 2번 집은 초록과 파랑중에서 골라서 칠해주어야 합니다. 저는 다이나믹 프로그래밍을 떠올렸습니다. 3 * n 크기의 2차원 배열을 사용하였습니다. 초기 값은 처음 집을 칠하는 것이므로, 각각의 칠한 비용으로 설정..
[BOJ] 백준 1912 연속합 (Swift) 문제 https://www.acmicpc.net/problem/1912 1912번: 연속합 첫째 줄에 정수 n(1 ≤ n ≤ 100,000)이 주어지고 둘째 줄에는 n개의 정수로 이루어진 수열이 주어진다. 수는 -1,000보다 크거나 같고, 1,000보다 작거나 같은 정수이다. www.acmicpc.net 풀이 연속된 수들을 선택해서 가장 큰 수를 구하는 문제입니다. 그렇다면 이 두가지로 나뉠 것입니다. 연속해서 자기 자신까지 선택한 경우가 더 큰 경우 자기 자신만 선택한 경우 다이나믹 프로그래밍을 사용해서 풀 수 있습니다. [2, 1, -4, 3, 4, -4, 6, 5, -5, 1] 수열이 주어졌을 때를 확인해 봅시다. 첫번째 수를 확인해봅시다. 2를 선택하는 것이 가장 큰 합일 것입니다. 두번째 수를..
[BOJ] 백준 9461 파도반 수열 (Swift) 문제 https://www.acmicpc.net/problem/9461 9461번: 파도반 수열 오른쪽 그림과 같이 삼각형이 나선 모양으로 놓여져 있다. 첫 삼각형은 정삼각형으로 변의 길이는 1이다. 그 다음에는 다음과 같은 과정으로 정삼각형을 계속 추가한다. 나선에서 가장 긴 변의 www.acmicpc.net 풀이 다이나믹 프로그래밍을 사용하여 풀 수 있는 문제입니다. 이 문제는 그림을 보고 점화식을 구했지만.. 증명하지는 못했습니다. 그림을 봤을 때, $f(n) = f(n - 1) + f(n - 5)$ 라는 것을 확인했습니다. 수열을 보면 $f(n) = f(n - 2) + f(n - 3)$도 될 것 같은데... 결론으로는 두 점화식 다 정답 처리가 되더라구요.. 소스코드 후기 규칙을 찾아서 풀긴 했는..
[BOJ] 백준 1904 01타일 (Swift) 문제 https://www.acmicpc.net/problem/1904 1904번: 01타일 지원이에게 2진 수열을 가르쳐 주기 위해, 지원이 아버지는 그에게 타일들을 선물해주셨다. 그리고 이 각각의 타일들은 0 또는 1이 쓰여 있는 낱장의 타일들이다. 어느 날 짓궂은 동주가 지원이 www.acmicpc.net 풀이 다이나믹 프로그래밍으로 풀 수 있는 문제입니다. N이 1일 때는 1만 만들 수 있고, N이 2일 때는 00, 11 로 두 가지를 만들 수 있습니다. N이 3일 때는 어떠할까요? N이 1일 때의 경우에서 "00" 타일 붙히기 + N이 2일때에서 "1"타일을 붙히기 일 것입니다. 따라서 100, 001, 111 로 3가지 경우일 것입니다. 이렇게 이전의 결과들을 바탕으로 다음 결과를 도출할 수 ..
[BOJ] 백준 9184 신나는 함수 실행 (Swift) 문제 https://www.acmicpc.net/problem/9184 9184번: 신나는 함수 실행 입력은 세 정수 a, b, c로 이루어져 있으며, 한 줄에 하나씩 주어진다. 입력의 마지막은 -1 -1 -1로 나타내며, 세 정수가 모두 -1인 경우는 입력의 마지막을 제외하면 없다. www.acmicpc.net 풀이 DP를 사용하여 풀 수 있는 문제입니다. DP는 점화식만 세운다면 쉽게 풀 수 있습니다. 이 문제에서는 점화식을 아예 주고 시작해서, 점화식에 맞게 코드를 작성해줍시다. 먼저, 저는 20 * 20 * 20의 3차원 배열을 선언해주었고, 초기값을 1로 갖고 있도록 하였습니다. 이제 이 3차원 배열을 점화식에 맞게 채워주었습니다. 바텀업 방식으로 풀이할 때는 입력을 받을 때, 0 보다 작거나 ..
[BOJ] 백준 24416 알고리즘 수업 - 피보나치 수 1 (Swift) 문제 https://www.acmicpc.net/problem/24416 24416번: 알고리즘 수업 - 피보나치 수 1 오늘도 서준이는 동적 프로그래밍 수업 조교를 하고 있다. 아빠가 수업한 내용을 학생들이 잘 이해했는지 문제를 통해서 확인해보자. 오늘은 n의 피보나치 수를 재귀호출과 동적 프로그래밍 www.acmicpc.net 풀이 단순히 문제만 보았을 때, 의사코드를 작성해서 직접 count를 해주는 것을 떠올릴 수 있습니다. 하지만, 재귀호출로 fib(40)을 호출한다면 어마어마하게 재귀호출을 하기 때문에 시간초과가 날 것입니다. 어떻게 코드1 횟수를 구할 수 있을까요? 단순히 생각해봅시다. fibo(3)을 구하려면 fibo(2), fibo(1)이 필요합니다. 그렇다면 코드 1을 2번 호출을 하겠..
[BOJ] 백준 1449 수리공 항승 (Swift) 문제 https://www.acmicpc.net/problem/1449 1449번: 수리공 항승 첫째 줄에 물이 새는 곳의 개수 N과 테이프의 길이 L이 주어진다. 둘째 줄에는 물이 새는 곳의 위치가 주어진다. N과 L은 1,000보다 작거나 같은 자연수이고, 물이 새는 곳의 위치는 1,000보다 작거나 www.acmicpc.net 풀이 그리디 알고리즘으로 풀이할 수 있습니다. 파이프의 길이는 최대 1000이므로, 1부터 1000까지 확인하면서 물이 세는 곳이라면, 길이가 L인 테이프를 붙여주어야 합니다. 그렇다면 물이 세는곳 + L 까지는 모두 테이프로 막아져있기 때문에, 물이 세는곳 + L부터 1000까지 다시 물이 세는곳을 확인해주고, 테이프의 수를 하나 늘려줍시다. 최대 1000까지 확인하였다면,..

반응형