코딩테스트/백준

[백준][C++]1325번 효율적인 해킹

윤깡패 2023. 6. 8. 23:37

문제

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) 자료구조

그래프(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