본문 바로가기

반응형

Java/Java 알고리즘 인프런

(110)
[Ch.08 - DFS] 04. 바둑이 승차 2. 바둑이 승차(DFS) 설명 철수는 그의 바둑이들을 데리고 시장에 가려고 한다. 그런데 그의 트럭은 C킬로그램 넘게 태울수가 없다. 철수는 C를 넘지 않으면서 그의 바둑이들을 가장 무겁게 태우고 싶다. N마리의 바둑이와 각 바둑이의 무게 W가 주어지면, 철수가 트럭에 태울 수 있는 가장 무거운 무게를 구하는 프로그램을 작성하세요. 입력 첫 번째 줄에 자연수 C(1
[Ch.08 - DFS] 03. 합이 같은 부분집합 1. 합이 같은 부분집합(DFS : 아마존 인터뷰) 설명 N개의 원소로 구성된 자연수 집합이 주어지면, 이 집합을 두 개의 부분집합으로 나누었을 때 두 부분집합의 원소의 합이 서로 같은 경우가 존재하면 “YES"를 출력하고, 그렇지 않으면 ”NO"를 출력하는 프로그램을 작성하세요. 둘로 나뉘는 두 부분집합은 서로소 집합이며, 두 부분집합을 합하면 입력으로 주어진 원래의 집합이 되어 합니다. 예를 들어 {1, 3, 5, 6, 7, 10}이 입력되면 {1, 3, 5, 7} = {6, 10} 으로 두 부분집합의 합이 16으로 같은 경우가 존재하는 것을 알 수 있다. 입력 첫 번째 줄에 자연수 N(1 LEVEL 6 //D(L, SUM)으로 만들기 //L: 부분집합의 원소로 -> [O/X] 분기 class Mai..
[Ch.08 - BFS] 03. 미로의 최단거리 통로 11. 미로의 최단거리 통로(BFS) 설명 7*7 격자판 미로를 탈출하는 최단경로의 길이를 출력하는 프로그램을 작성하세요. 경로의 길이는 출발점에서 도착점까지 가는데 이동한 횟수를 의미한다. 출발점은 격자의 (1, 1) 좌표이고, 탈출 도착점은 (7, 7)좌표이다. 격자판의 1은 벽이고, 0은 도로이다. 격자판의 움직임은 상하좌우로만 움직인다. 미로가 다음과 같다면 위와 같은 경로가 최단 경로의 길이는 12이다. 입력 첫 번째 줄부터 7*7 격자의 정보가 주어집니다. 출력 첫 번째 줄에 최단으로 움직인 칸의 수를 출력한다. 도착할 수 없으면 -1를 출력한다. 예시 입력 1 0 0 0 0 0 0 0 0 1 1 1 1 1 0 0 0 0 1 0 0 0 1 1 0 1 0 1 1 1 1 0 1 0 0 0 1 0 ..
[Ch.07 - BFS] 02. 송아지 찾기 (+BFS : 상대트리탐색) 8. 송아지 찾기 1(BFS : 상태트리탐색) 설명 현수는 송아지를 잃어버렸다. 다행히 송아지에는 위치추적기가 달려 있다. 현수의 위치와 송아지의 위치가 수직선상의 좌표 점으로 주어지면 현수는 현재 위치에서 송아지의 위치까지 다음과 같은 방법으로 이동한다. 송아지는 움직이지 않고 제자리에 있다. 현수는 스카이 콩콩을 타고 가는데 한 번의 점프로 앞으로 1, 뒤로 1, 앞으로 5를 이동할 수 있다. 최소 몇 번의 점프로 현수가 송아지의 위치까지 갈 수 있는지 구하는 프로그램을 작성하세요. 입력 첫 번째 줄에 현수의 위치 S와 송아지의 위치 E가 주어진다. 직선의 좌표 점은 1부터 10,000까지이다. 출력 점프의 최소횟수를 구한다. 답은 1이상이며 반드시 존재합니다. 예시 입력 1 5 14 예시 출력 1 ..
[Ch.10 - DP] 03. 최대 부분 증가수열 [+LIS] 3. 최대 부분 증가수열 설명 N개의 자연수로 이루어진 수열이 주어졌을 때, 그 중에서 가장 길게 증가하는(작은 수에서 큰 수로) 원소들의 집합을 찾는 프로그램을 작성하라. 예를 들어, 원소가 2, 7, 5, 8, 6, 4, 7, 12, 3 이면 가장 길게 증가하도록 원소들을 차례대로 뽑아내면 2, 5, 6, 7, 12를 뽑아내어 길이가 5인 최대 부분 증가수열을 만들 수 있다. 입력 첫째 줄은 입력되는 데이터의 수 N(3≤N≤1,000, 자연수)를 의미하고, 둘째 줄은 N개의 입력데이터들이 주어진다. 출력 첫 번째 줄에 부분증가수열의 최대 길이를 출력한다. 예시 입력 1 8 5 3 7 8 6 2 9 4 예시 출력 1 4 dy[i] : 수열에서 i번째 숫자를 마지막으로 하는 최대 증가 수열의 길이 dy[..
[Ch.10 - DP] 02. 돌다리 건너기 1. 계단오르기 설명 철수는 계단을 오를 때 한 번에 한 계단 또는 두 계단씩 올라간다. 만약 총 4계단을 오른다면 그 방법의 수는 1+1+1+1, 1+1+2, 1+2+1, 2+1+1, 2+2 로 5가지이다. 그렇다면 총 N계단일 때 철수가 올라갈 수 있는 방법의 수는 몇 가지인가? 입력 첫째 줄은 계단의 개수인 자연수 N(3≤N≤35)이 주어집니다. 출력 첫 번째 줄에 올라가는 방법의 수를 출력합니다. 예시 입력 1 7 예시 출력 1 21 돌다리를 건너야 하므로 dy[n+1]을 반환해야 한다. dy = new int[n+2]; return dy[n+1]; package dynamic.ch10; import java.util.Scanner; //돌다리 건너기 //한칸 혹은 두칸씩 마지막에 도달 publi..
[Ch.10 - DP] 01. 계단오르기 1. 계단오르기 설명 철수는 계단을 오를 때 한 번에 한 계단 또는 두 계단씩 올라간다. 만약 총 4계단을 오른다면 그 방법의 수는 1+1+1+1, 1+1+2, 1+2+1, 2+1+1, 2+2 로 5가지이다. 그렇다면 총 N계단일 때 철수가 올라갈 수 있는 방법의 수는 몇 가지인가? 입력 첫째 줄은 계단의 개수인 자연수 N(3≤N≤35)이 주어집니다. 출력 첫 번째 줄에 올라가는 방법의 수를 출력합니다. 예시 입력 1 7 예시 출력 1 21 복잡한 문제의 경우 직관적으로 알 수 있는 단위인, 작은 문제들로 쪼갠 후, 확장을 하는 방식으로, 메모이제이션을 이용해 해결 -> DP (Dynamic Programming) dy[7]=? dy[1]=1 dy[2]=2 dy[3]은 dy[1]에서 혹은 dy[2]에서 ..
[Ch.07 - BFS] 01. 이진트리 순회 (+ 넓이우선탐색 BFS) 1. 이진트리 순회 (넓이우선탐색 : 레벨탐색) Breadth First Search (BFS : 낮은 레벨부터 탐색) -> 현재 위치에서의 최단 거리 탐색에 사용 //큐에 넣어서, 낮은 레벨부터 출력 Queue Q = new LinkedList(); Q.offer(root); int L=0; while(!Q.isEmpty()) { //비어있으면 거짓, 비어있지 않으면 참 -> 비어있을 때까지 반복 ~ } L++; 큐의 원소 개수를 위한 변수 설정 현재 노드 출력 연결된 자식들 넣기 현재 노드의 왼쪽 노드가 존재한다면, 왼쪽 노드 삽입 현재 노드의 오른쪽 노드가 존재한다면, 오른쪽 노드 삽입 큐 그리기 : 1 넣기 -> 1과 연결된 2,3 넣기 -> 2와 연결된 4,5 넣기 -> 3과 연결된 6,7 ->..

반응형