[BOJ / C++] 구슬 찾기 (그래프)

2025. 9. 9. 00:06·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/2617

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

int bfsCnt(int n, vector<vector<int>>& adj, int st) {
    vector<bool> vis(n+1, false);
    queue<int> Q;

    Q.push(st);
    vis[st] = true;
    int cnt = 0;

    while (!Q.empty()) {
        int cur = Q.front(); Q.pop();
        for (int nxt : adj[cur]) {
            if (vis[nxt]) continue;
            Q.push(nxt);
            vis[nxt] = true;
            cnt++;
        }
    }

    return cnt;
}

int main() {
    ios::sync_with_stdio(0); cin.tie(0);

    int n, m;
    cin >> n >> m;

    vector<vector<int>> adj_light(n+1);
    vector<vector<int>> adj_heavy(n+1);

    for (int i = 0; i < m; i++) {
        int a, b;
        cin >> a >> b;

        adj_light[a].push_back(b);
        adj_heavy[b].push_back(a);
    }

    int exclude = 0;

    // light 탐색
    for (int i = 1; i < n+1; i++) {
        if (bfsCnt(n, adj_light, i) > (n/2)) exclude++;
    }

    // heavy 탐색
    for (int i = 1; i < n+1; i++) {
        if (bfsCnt(n, adj_heavy, i) > (n/2)) exclude++;
    }

    cout << exclude;
}

 

 

2. 시간복잡도

인접리스트에서 BFS 순회는 O(v+e)이다. n = 99, m = 5,000이고 모든 정점에서 BFS를 해야하므로 O(v * (v+e)) = 100 * 5100 < 10^8 이므로 시간제한 1초내에 통과 가능하다.

 

 

3. 분석

 

무거운 것을 adj_heavy, 가벼운 것을 adj_light에 따로 그래프 정보를 저장하고 노드마다 BFS로 연결 노드 개수를 세서 cnt > n/2이면 중심에 올 수 없다라고 하는 아이디어를 떠올려야했다. 이 부분이 참신했다. 무거운 것과 가벼운 것을 따로 그래프를 나눠서 정보를 저장할 수도 있었다.

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ / C++] 노드사이의 거리 (트리)  (0) 2025.09.11
[BOJ / C++] 트리와 쿼리 (트리)  (0) 2025.09.10
[BOJ / C++] 주사위 굴리기 (시뮬레이션)  (0) 2025.09.01
[BOJ / C++] 비밀 이메일 (문자열)  (0) 2025.08.28
[BOJ / C++] 이분 그래프 (그래프)  (0) 2025.08.20
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 노드사이의 거리 (트리)
  • [BOJ / C++] 트리와 쿼리 (트리)
  • [BOJ / C++] 주사위 굴리기 (시뮬레이션)
  • [BOJ / C++] 비밀 이메일 (문자열)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (172) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (16)
        • Java (8)
        • Spring (4)
        • Docker (4)
      • 코딩테스트 (95) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (12) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 구슬 찾기 (그래프)
상단으로

티스토리툴바