티스토리 뷰

728x90

문제

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

 

5567번: 결혼식

예제 1의 경우 2와 3은 상근이의 친구이다. 또, 3과 4는 친구이기 때문에, 4는 상근이의 친구의 친구이다. 5와 6은 친구도 아니고, 친구의 친구도 아니다. 따라서 2, 3, 4 3명의 친구를 결혼식에 초대

www.acmicpc.net

 

 

풀이 및 소스코드

 

문제를 보면 친구의 친구까지만 결혼식에 초대한다고 나와있다.

따라서 BFS로 돌리되, 거리가 2를 넘어가면 종료해주어야 한다.

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue;
import java.util.StringTokenizer;

public class Main {
	public static void main(String[] args) throws NumberFormatException, IOException {
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		StringTokenizer st;
		int res = 0;
		int n = Integer.parseInt(br.readLine());
		int m = Integer.parseInt(br.readLine());

		ArrayList<Integer>[] f = new ArrayList[n];
		for (int i = 0; i < n; i++) {
			f[i] = new ArrayList<Integer>();
		}
		for (int i = 0; i < m; i++) {
			st = new StringTokenizer(br.readLine());
			int a = Integer.parseInt(st.nextToken()) - 1;
			int b = Integer.parseInt(st.nextToken()) - 1;
			f[a].add(b);
			f[b].add(a);
		}

		boolean[] v = new boolean[n];

		v[0] = true;

		Queue<Integer> q = new LinkedList<Integer>();

		q.add(0);
		int cnt = 0;
		while (!q.isEmpty()) {
			int size = q.size();
			for (int i = 0; i < size; i++) {
				int x = q.poll();
				for (int nowx : f[x]) {
					if (v[nowx])
						continue;
					v[nowx] = true;
					res++;
					q.add(nowx);
				}
			}
			cnt++;
			if(cnt==2) break;
            // 거리 1 : 친구
            // 거리 2 : 친구의 친구
            // 거리가 2가 되면 종료
		}

		System.out.println(res);
	}
}
반응형