작성
·
109
0
출력에 변동을 주어서 레벨 별로 정점을 나오게 했습니다.
코드가 맞는지 검사해주시면 감사하겠습니다.
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.*;
public class Main {
static boolean visit[];
static ArrayList<ArrayList<Integer>> graph;
static int n;
public static StringBuilder bfs(int v) {
StringBuilder sb = new StringBuilder();
Queue<Integer> queue = new LinkedList<>();
queue.offer(v);
visit[v] = true;
int L = 0;
while (!queue.isEmpty()) {
sb.append(L).append(" : ");
int len = queue.size();
for (int i = 0; i < len; i++) {
int cv = queue.poll();
sb.append(cv).append(" ");
for (int nv : graph.get(cv)) {
if (!visit[nv]) {
visit[nv] = true;
queue.offer(nv);
}
}
}
L++;
sb.append('\n');
}
return sb;
}
public static void main(String[] args) throws Exception {
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(bufferedReader.readLine());
n = Integer.parseInt(st.nextToken());
int m = Integer.parseInt(st.nextToken());
visit = new boolean[n + 1];
graph = new ArrayList<>();
for (int i = 0; i <= n; i++) {
graph.add(new ArrayList<>());
}
for (int i = 0; i < m; i++) {
st = new StringTokenizer(bufferedReader.readLine());
int from = Integer.parseInt(st.nextToken());
int to = Integer.parseInt(st.nextToken());
graph.get(from).add(to);
}
System.out.println(bfs(1));
}
}
답변 2
0
0
안녕하세요, 인프런 AI 인턴입니다. rlgus4531님.
작성하신 코드를 보니, BFS(Breadth-First Search) 알고리즘을 사용하여 그래프의 각 레벨 별로 정점을 출력하도록 구현하셨네요. 코드는 잘 작성되었으며, 주어진 문제의 요구사항을 만족하고 있는 것으로 보입니다. 특히, StringBuilder
를 사용하여 레벨 별로 연결된 정점을 깔끔하게 출력할 수 있도록 구성하신 부분이 인상적입니다.
하지만, 몇 가지 고려해볼 수 있는 소소한 개선점을 드리자면:
예외 처리:
visit
배열을 boolean
대신 int
배열로 사용하여 정점의 방문 여부와 동시에 레벨 정보를 저장할 수도 있지만, 현재 방식도 직관적이므로 유지해도 괜찮습니다.출력 형식:
현재 코드로도 충분히 잘 구현되었으므로, 학습의 목적으로 여러 방식으로 시도해보시는 것을 추천드립니다.
유사한 질문의 답변도 참고하시면 더욱 다양한 접근 방식과 개선점을 발견하실 수 있습니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.