[프로그래머스] 가장 먼 노드 (java) Bfs

2020-03-20

가장 먼 노드 (프로그래머스 > Dfs_Bfs)

문제 링크

문제설명

n개의 노드가 있는 그래프가 있습니다. 각 노드는 1부터 n까지 번호가 적혀있습니다. 1번 노드에서 가장 멀리 떨어진 노드의 갯수를 구하려고 합니다. 가장 멀리 떨어진 노드란 최단경로로 이동했을 때 간선의 개수가 가장 많은 노드들을 의미합니다.

노드의 개수 n, 간선에 대한 정보가 담긴 2차원 배열 vertex가 매개변수로 주어질 때, 1번 노드로부터 가장 멀리 떨어진 노드가 몇 개인지를 return 하도록 solution 함수를 작성해주세요.

제한사항
  • 노드의 개수 n은 2 이상 20,000 이하입니다.
  • 간선은 양방향이며 총 1개 이상 50,000개 이하의 간선이 있습니다.
  • vertex 배열 각 행 [a, b]는 a번 노드와 b번 노드 사이에 간선이 있다는 의미입니다.
입출력 예
n vertex return
6 [[3, 6], [4, 3], [3, 2], [1, 3], [1, 2], [2, 4], [5, 2]] 3
입출력 예 설명

예제의 그래프를 표현하면 아래 그림과 같고, 1번 노드에서 가장 멀리 떨어진 노드는 4,5,6번 노드입니다.

image.png


풀이

0322.PNG

후기 (1h)

음.. 항상 연결되어있는 문제를 풀때는 인접행렬 방식으로 풀어왔는데, 그러면 항상 메모리 초과에 걸려서 코드를 고치는데 시간을 다쓰는 경우가 많았다.

따라서, 행렬을 사용하긴 하되, 배열을 전부 nXn을 만들어서 사용하지말고, 인접한 부분의 정보를 주는 크기만큼만 행렬을 만들고 그를 사용하기로 했다.

또한, 네트워크 문제처럼 가야하는 곳이 n개로 정해져있는 경우에는 visited[n]을 만들어 사용했던 것을 잊지말고 사용하자!

  • 전체 다 돌아보려고 하지말고, 최적을 구하려고 노력하자
  • 안그러면 다시 푸는데에 시간이 너무 오래걸린다…
  • 가끔 text를 인식 못하면 지우고 그냥 image로 바꿔 올리는데 뭐가 잘못된건지 모르겠다..으앙