[BOJ] 13023 ABCDE

SSOYEONG·2022년 3월 17일
0

Problem Solving

목록 보기
1/60
post-thumbnail

🔗 Problem

https://www.acmicpc.net/problem/13023

👩‍💻 Code

package baekjoon;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.StringTokenizer;

// ABCDE 일직선 관계 찾기

public class BJ13023 {
	
	static int numV;
	static int numE;
	static ArrayList<Integer>[] adj;	// 2차원 배열 사용하면 시간초과 발생
	static boolean[] visited;
	
	@SuppressWarnings("unchecked")
	public static void main(String[] args) throws IOException {
		
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st = new StringTokenizer(br.readLine());
		
		numV = Integer.parseInt(st.nextToken());
		numE = Integer.parseInt(st.nextToken());
		
		adj = new ArrayList[numV];
		visited = new boolean[numV];
		for(int i = 0; i < numV; i++) {
			adj[i] = new ArrayList<Integer>();
		}

		for(int i = 0; i < numE; i++) {
			st = new StringTokenizer(br.readLine());
			int from = Integer.parseInt(st.nextToken());
			int to = Integer.parseInt(st.nextToken());
			adj[from].add(to);
			adj[to].add(from);
		}
		
		if(numE < 4) {
			System.out.println(0);
			System.exit(0);
		}
		
		for(int i = 0; i < numV; i++) {
			dfs(i, 0);
		}
		
		System.out.println(0);

	}
	
	private static void dfs(int start, int cnt) {
		
		visited[start] = true;
		if(cnt == 4) {
			System.out.println(1);
			System.exit(0);
		}
	
		for(int i = 0; i < adj[start].size(); i++) {
			int v = adj[start].get(i);
			if(!visited[v]) {
				dfs(v, cnt + 1);	// argument에 증감 연산자 사용 시 호출 순서에 의해 값이 달라짐
			}
		}
		
		visited[start] = false;		// 재탐색을 위해 방문한 노드는 false 처리
	}

}

📌 Note

아이디어

  • DFS 문제로, 조건을 만족하지 않으면 depth를 타고 올라와야 하기 때문에 visited[start] = false로 재설정해야 한다.

시간초과 발생

  • 친구 관계 수 M(edges)가 최대 2000으로 작기 때문에 2차원 배열을 생성하는 것보다 List를 사용하여 인접 노드를 저장하는 것이 효율적이다.
profile
Übermensch

0개의 댓글