Algorithm/Baekjoon
[백준] 4963 섬의 개수 - Java
[백준] 4963 섬의 개수 - Java
2022.05.27지난번에 풀었던 유기농 배추와 유사한 문제이다. 매 테스트케이스마다 지도와 방문 여부, 정답 변수를 초기화 해 주고 dfs를 돌려 탐색하자. import java.util.*; import java.io.*; public class Main { static int N; static int M; static int map[][]; static boolean[][] visit; static int cnt; static int[][] dir = {{1,0}, {-1,0}, {0,-1}, {0,1}, {1,1}, {1,-1}, {-1,1}, {-1,-1}}; public static void main(String[] args) throws IOException { BufferedReader br = new Bu..
[백준] 1012 유기농 배추 - Java
[백준] 1012 유기농 배추 - Java
2022.05.27배추가 심어진 밭을 이차원 배열로 표현하고, 그 배열을 그래프로 표현해 풀 수 있는 문제이다. dfs와 bfs 모두 사용할 수 있다. 이번에는 재귀를 통한 dfs를 사용해 풀어보자. import java.util.*; import java.io.*; public class Main { static int N; static int M; static int K; static int[][] map; static boolean[][] visit; static int[][] dir = {{1,0}, {0,1}, {-1,0}, {0,-1}}; static int cnt; public static void main(String[] args) throws IOException { BufferedReader br = n..
[백준] 3055 탈출 - Java
[백준] 3055 탈출 - Java
2022.05.27물이 전이되는 조건 때문에 처리해줘야 하는 요소가 많다. 일단 최단시간을 구하는게 목적이니, bfs를 돌리면서 최단 시간을 갱신하면 풀 수 있을 것 같다. 고슴도치는 물이 전이된 곳에 갈 수 없으니 물에 대한 bfs를 먼저 돌려 언제 물이 해당 위치에 전이되는지 기록하자. 그 후는 항상 하던대로 고슴도치에 대한 bfs를 수행하면 된다. import java.util.*; import java.io.*; public class Main { static int N; static int M; static char[][] map; static int[][] dist_water; static int[][] dist_hedgehog; static boolean[][] visit; static int[][] dir ..
[백준] 1697 숨바꼭질 - Java
[백준] 1697 숨바꼭질 - Java
2022.05.27최소 시간을 구하라고 했으니.. bfs를 사용해 dist를 갱신하고 최소 시간을 출력하면 될 것 같다. 기존 문제는 격자 혹은 그래프를 대놓고 줘서 그래프를 어떻게 구성해야 할 지 쉽게 떠올릴 수 있었는데, 이번 문제에서는 그래프에 대한 단서가 별로 없다. 먼저 그래프를 디자인해보자. 정점은 술래가 위치한 상태 / 간선은 +1. -1. *2 세 가지로 구성할 수 있겠다. 위의 조건에 맞춰 그래프를 구성하고 bfs를 돌려 답을 구하자. import java.util.*; import java.io.*; public class Main { static int N; static int K; static int[] dist; static boolean[] visit; public static void main(..
[백준] 7562 나이트의 이동 - Java
[백준] 7562 나이트의 이동 - Java
2022.05.27bfs로 격자를 순회하면서 거리를 갱신해 풀 수 있는 문제다. 관련 문제를 많이 풀어서 그래프 유형에 익숙해지자. import java.util.*; import java.io.*; public class Main { static int I; static int ans; static int[][] map; static boolean[][] visit; static int[][] dist; static int[][] dir = {{2,-1}, {2,1}, {1,-2}, {1,2}, {-2,-1}, {-2,1}, {-1,-2}, {-1,2}}; public static void main(String[] args) throws IOException { BufferedReader br = new Buffered..
[백준] 14502 연구소 - Java
[백준] 14502 연구소 - Java
2022.05.261. 벽을 설치할 수 있는 위치 탐색 2. 벽을 설치하는 모든 경우를 고려해야 한다. dfs로 벽을 설치하고 설치가 완료됐으면 bfs로 바이러스의 수를 기록한다. import java.util.*; import java.util.concurrent.LinkedBlockingDeque; import java.io.*; public class Main { static int N; static int M; static int wall; static int ans; static int[][] map; static boolean[][] visit; static int[][] able_wall; static int[][] dir = {{1, 0}, {0, 1}, {-1, 0}, {0, -1}}; public sta..
[백준] 13904 과제 - Java
[백준] 13904 과제 - Java
2022.05.23그리디와 우선순위 큐 자료구조를 사용해 풀 수 있다. 우선순위 큐는 그냥 쓰면 되는데.. 그리디는 어떻게 사용해야 할까? 일단 객체 하나 만들고 점수 내림차순으로 정렬하자. 그 후 계산을 시작한다. 하루에 과제 하나를 끝낼 수 있으니, 기간이 많이 남은 과제는 최대한 나중에 하면 된다. 점수에 대해 정렬이 된 상태라서, 이렇게 작성하면 고득점을 얻을 수 있다. import java.util.*; import java.io.*; public class Main { public static void main(String args[]) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int..
[백준] 16987 계란으로 계란치기 - Java
[백준] 16987 계란으로 계란치기 - Java
2022.05.23백트래킹으로 모든 경우를 계산해 풀 수 있는 문제이다. (브루트포스 느낌) 재귀는 반복문으로 구현할 수 있고 반복문은 재귀로 구현할 수 있듯, 이 문제도 반복문을 사용해 풀 수 있을 것 같긴 하다. 재귀적 구조에 익숙해져야겠다. 아직은 너무 어색하다. import java.util.*; import java.io.*; public class Main { static int N = 0; static int cnt = 0; static Egg[] egg; static int max = 0; public static void main(String args[]) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(Sy..
[백준] 1759 암호 만들기 - Java
[백준] 1759 암호 만들기 - Java
2022.05.23백트래킹으로 풀 수 있는 문제이다. 조건은, 모음이 1개 이상 / 자음이 2개 이상이다. 암호의 문자는 하나씩밖에 사용할 수 없으니 백트래킹 함수는 인자를 두 개 받도록 설정해 처리해주자. 값의 후보가 되는 요소들은 리스트로 담아서 풀 수 있는데, 이번에는 배열을 사용해서 풀어보자. arr의 값이 cand의 인덱스로 접근해서 답을 출력한다. import java.util.*; import java.io.*; public class Main { static int L, C = 0; static int[] arr; static char[] cand; public static void main(String args[]) throws IOException { BufferedReader br = new Buffe..
[백준] 2448 별찍기 11 - Java
[백준] 2448 별찍기 11 - Java
2022.05.21재귀 문제임을 파악하자. 일단 주어진 예시를 잘라서 재귀의 basis를 구한 후 접근해야 한다. N = 3 * 2^k 이므로, 이차원 배열의 행 : 3 * 2^k 이차원 배열의 열 : 3 * 2^(k+1) 위의 식을 기억하고 점화식을 작성한 후 코드를 작성하자. import java.util.*; import java.io.*; public class Main { static int N; static char[][] map; static char[][] basis = {{' ',' ','*',' ',' '}, {' ', '*', ' ','*', ' '}, {'*','*','*','*','*'}}; public static void main(String args[]) throws IOException { ..
[백준] 5426 비밀 편지 - Java
[백준] 5426 비밀 편지 - Java
2022.05.19입력받은대로 2차원 배열에 저장하고 뒤에서부터 시작해 읽어 주면 쉽게 풀 수 있는 문제이다. 조금 다르게 풀어보자. 배열을 회전시켜서 풀 수 있지 않을까? 2차원 배열을 시계 방향으로 90도 회전하는 메서드를 구현한 후 입력받은 2차원 배열을 3번 회전시키면 편지의 원본을 얻을 수 있다. 회전 알고리즘은 코드를 참조하자. import java.util.*; import java.io.*; public class Main { public static void main(String args[]) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int N = Integer.parseInt(..
[백준] 6588 골드바흐의 추측 - Java
[백준] 6588 골드바흐의 추측 - Java
2022.05.171. 리스트로 접근하면 시간 초과가 발생한다. 2. 이중 반복문으로 모든 소수쌍을 찾는 식으로 접근하면 시간 초과가 발생한다. 3. 처음에 찾은 소수가 b - a 값이 최대인 소수이다. 한개의 소수를 찾으면 다른 수는 정해진다. 이 부분에 집중해 시간 초과 없이 풀어보자. import java.util.*; import java.io.*; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringBuilder sb = new StringBuilder(); boolean prime..