문제
https://www.acmicpc.net/problem/1325
1325번: 효율적인 해킹
첫째 줄에, N과 M이 들어온다. N은 10,000보다 작거나 같은 자연수, M은 100,000보다 작거나 같은 자연수이다. 둘째 줄부터 M개의 줄에 신뢰하는 관계가 A B와 같은 형식으로 들어오며, "A가 B를 신뢰한
www.acmicpc.net
풀이
'가장 많은 컴퓨터를 해킹할 수 있는 컴퓨터' : 신뢰를 가장 많이 받는 컴퓨터
그래프(Graph) 자료구조
그래프(Graph) 자료구조 노드와 에지로 구성된 집합 노드(Node) : 데이터를 표현하는 단위 에지(Edge) : 노드를 연결 에지 리스트(Edge List) 노드를 배열에 저장하여 에지 표현 에지를 중심으로 그래프
soobin0821.tistory.com
코드
#include <iostream>
#include <vector>
using namespace std;
void DFS(int n);
static vector<vector<int>> graph;
static vector<bool> visited;
static int num;
int main()
{
ios::sync_with_stdio(false);
cin.tie(NULL);
cout.tie(NULL);
int N, M;
cin >> N >> M;
graph.resize(N + 1);
for(int i = 0; i < M; i++)
{
int A, B;
cin >> A >> B;
graph[B].push_back(A); // 인접 리스트 graph에 그래프 데이터 저장
}
visited.resize(N + 1, false);
vector<int> count(N + 1, 0);
for(int i = 1; i <= N; i++)
{
fill(visited.begin(), visited.end(), false); // visited 배열 초기화하기
num = 0;
DFS(i); // 모든 노드에서 DFS 실행
count[i] = num;
}
// count 배열에서 가장 큰 수 찾기
int max = 0;
for(int i = 1; i <= N; i++)
{
if(max < count[i])
{
max = count[i];
}
}
for(int i = 1; i <= N; i++)
{
// count 배열에서 max와 같은 값을 가진 index를 정답으로 출력
if(count[i] == max)
{
cout << i << " ";
}
}
return 0;
}
// DFS 구현
void DFS(int n)
{
visited[n] = true; // visited 배열에 현재 노드 방문 기록
num++;
for(int node : graph[n])
{
if(visited[node] == false)
{
DFS(node);
}
}
}
728x90
'코딩테스트 > 백준' 카테고리의 다른 글
[백준][C++]1541번 잃어버린 괄호 (0) | 2023.06.09 |
---|---|
[백준][C++]1463번 1로 만들기 (0) | 2023.06.09 |
[백준][C++]1717번 집합의 표현 (0) | 2023.06.07 |
[백준][C++]1260번 DFS와 BFS (0) | 2023.06.07 |
[백준][C++]1068번 트리 (0) | 2023.06.03 |