반응형
문제 : https://programmers.co.kr/learn/courses/30/lessons/49189
서론
그래프 문제.
풀이
그래프를 탐색해서 가장 먼 노드들을 찾는다.
그래프 탐색 알고리즘은 DFS/BFS가 있는데, 최단거리 문제를 제외하고는 항상 DFS로 구현했던지라 이번에도 그렇게 했다. 그리고 문제 발생
3번 노드는 1번노드에서 한칸 떨어져 있지만 1 - 2 - 3순으로 탐색해서 2칸 떨어진것으로 인식할 수 있다. 방문할때 조건을 잘 설정해주면 될것 같기도 하지만 애초에 이런 문제가 없는 BFS로 다시 구현했다.
그래프를 만들고 노드들의 거리를 저장하는 배열을 만든다.
BFS로 탐색하면서 방문할 노드의 거리는 이전 노드의 거리에서 +1한다. 그리고 노드의 거리 중 최대값은 변수에 저장하여 기억한다.
탐색이 끝나면 노드들의 거리 배열에서 최대값과 같은 노드들의 개수를 결과로 가져온다.
디버깅
DFS에서 BFS로 수정
구현
// c++
#include <string>
#include <vector>
#include <algorithm>
#include <iostream>
#include <queue>
using namespace std;
int node[20001];
int M = 0;
vector<vector<int>>g;
void init(int n, vector<vector<int>> &edge){
g.resize(n+1);
for(int i=0, size=edge.size();i<size;i++){
int a = edge[i][0];
int b = edge[i][1];
g[a].push_back(b);
g[b].push_back(a);
}
}
void bfs(){
queue<int>q;
q.push(1);
node[1] = 1;
while(!q.empty()){
int cur = q.front();
q.pop();
for(int i=0, size = g[cur].size();i<size;i++){
if(node[g[cur][i]] == 0){
node[g[cur][i]] = node[cur]+1;
q.push(g[cur][i]);
M = max(M, node[g[cur][i]]);
}
}
}
}
int solution(int n, vector<vector<int>> edge) {
int answer = 0;
init(n, edge);
bfs();
for(int i=1;i<=n;i++){
if(node[i] == M) answer++;
//cout<<i<<" "<<node[i]<<endl;
}
return answer;
}
최근댓글