[Java] 백준 11403 : 경로 찾기
·
Algorithm
문제 링크 1. 처음 문제를 보았을 때, 방향 그래프 인접 행렬이라는 점에서 조금 복잡하게 생각했다. 2. 자료구조 수업시간 때 인접 리스트 구성한 것을 떠올려 보면, 무방향 그래프에서 1에서 2로 가는 간선이 있다면 2에서 1로 가는 간선도 인접 리스트에 추가를 했었다. 방향 그래프라면 1에서 2로 가는 간선만 추가할 것이다. 이를 통해 그냥 배열을 순회하는 기본적인 BFS 문제와 다를 게 없다고 판단했다. 다만 사이클 생기는 부분을 주의해야 할 것이다. $0$번째 행부터 $n-1$번째 행까지 각 행에 대하여 BFS 탐색을 한다. 3. import java.util.LinkedList; import java.util.Queue; import java.util.Scanner; public class Ma..
[Java] 백준 14502 : 연구소
·
Algorithm
https://www.acmicpc.net/problem/14502 1. 한 2.5시간 정도 소요되었던 것 같다. 처음 문제를 보았을 때, 지금까지 풀었던 그래프 문제 알고리즘을 모두 적용하면 풀 수 있을 것이라 생각해서 코드를 써내려 갔다. 근데 코드를 써내려 가면서도 이중 for 문이 너무 많이 나와 비효율적이지 않을까 생각했지만, 시간제한이 2초이므로 문제없다고 판단했다. (사실 코드 써 내려가면서 갸우뚱만 3번 정도 한 듯..) 근데 답이 출력되지 않아 고민해보니 벽을 세우는 알고리즘을 잘못 선택했다는 것을 알아챘다. 조합 알고리즘을 잘못 작성하였다. 이 부분은 이전에 풀었던 조합 문제를 떠올려 적용하려고 했지만, 2차원 배열의 조합 구하는 것은 처음 접하여 풀이를 참고하였다. 2. 문제의 메커니..
[Java] 백준 11724 : 연결 요소의 개수
·
Algorithm
https://www.acmicpc.net/problem/11724 1. 학교에서 자료구조 수업시간에 배운 내용이다. 시험 준비할 때 중요하다고 생각해서 공부해두었기에 생각이 났다. (정○○ 교수님 수업 정말 알차게 열정적으로 해주셔서 감사합니다..) 2. 기본적인 DFS 탐색을 하되, 연결되지 않은 그래프는 한 번에 탐색되지 않는다. 따라서 방문하지 않은 노드를 찾아 DFS를 수행한다. 수업할 때 공부했던 자료를 참고하자. 3. import java.util.Scanner; public class Main { static int[][] graph; static boolean[] visited; public static void main(String[] args) throws Exception { Sca..
[Java] 백준 1012 : 유기농 배추
·
Algorithm
https://www.acmicpc.net/problem/1012 1. 문제를 처음 읽었을 때, 테스트 케이스 2의 결과가 2라는 것이 이해가 가지 않았다. 문제를 다시 천천히 읽어보고 해석해보니 결국 모여있는 배추 집합의 수를 구하는 문제였다. 전에 풀었던 '백준 2667 : 단지 번호 붙이기' 문제와 유사하다는 것을 알 수 있었다. (그때는 C언어로 풀었는데 이번에는 Java로 풀어보게 되네.. 확실히 망할 포인터 쓰는 C보다는 Java가 더 편리한 것 같다.) 2. BFS 방식을 사용했다. 문제를 풀고 DFS 풀이를 찾아보았는데, 코드가 더 깔끔했고 문제의 $N, M$ 범위가 작아 DFS로 풀어도 시간 초과하지 않는다는 것을 알 수 있었다. 문제는 다음과 같은 메커니즘을 택했다. 1. 배열의 모든 ..
squareyun
'그래프' 태그의 글 목록 (2 Page)