인프런 커뮤니티 질문&답변
숙제 검사 부탁드립니다.
작성
·
113
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배열로 사용하여 정점의 방문 여부와 동시에 레벨 정보를 저장할 수도 있지만, 현재 방식도 직관적이므로 유지해도 괜찮습니다.
출력 형식:
- 출력할 때 레벨 별로 리스트의 형태로 변환하여 보일 수 있도록 추가적인 포매팅을 적용해 볼 수 있습니다.
- 출력할 때 레벨 별로 리스트의 형태로 변환하여 보일 수 있도록 추가적인 포매팅을 적용해 볼 수 있습니다.
현재 코드로도 충분히 잘 구현되었으므로, 학습의 목적으로 여러 방식으로 시도해보시는 것을 추천드립니다.
유사한 질문의 답변도 참고하시면 더욱 다양한 접근 방식과 개선점을 발견하실 수 있습니다:
- 숙제 코드 리뷰 부탁드립니다 - 이 답변에서는 BFS를 통해 그래프를 탐색하고, 방문 레벨을 계산하는 데 대한 지식 공유가 이루어졌습니다.
- 숙제검사 - Java로 BFS를 활용하여 그래프의 레벨을 구하는 다른 구현 방법을 살펴보고 비교해 보실 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





