Algorithm/BOJ

[BOJ 25516] 거리가 k이하인 트리 노드에서 사과 수확하기 C++

surimi🍥 2023. 3. 9. 14:42
반응형

난이도: Silver 2
번호: 25516
생성일: March 9, 2023 2:39 PM
알고리즘 분류: 그래프 이론, 그래프 탐색, 깊이 우선 탐색, 너비 우선 탐색, 트리
언어: C++

25516번: 거리가 k이하인 트리 노드에서 사과 수확하기

C++

#include <cstdio>
#include <queue>
#include <vector>

using namespace std;

int N, K;
vector<vector<int>> map;
vector<int> apple;
vector<bool> visit;

int BFS()
{
    queue<int> Q;
    Q.push(0);
    visit[0] = true;
    int depth = 0;
    int cnt = apple[0];

    while (!Q.empty() && depth < K)
    {
        int size = Q.size();

        while (size--)
        {
            int cur = Q.front();
            Q.pop();

            for (int i : map[cur])
            {
                if (visit[i])
                    continue;

                Q.push(i);
                visit[i] = true;
                cnt += apple[i];
            }
        }
        depth++;
    }
    return cnt;
}

int main(void)
{
    scanf("%d %d", &N, &K);

    map.resize(N + 1);
    apple.resize(N + 1);
    visit.resize(N + 1);

    for (int i = 0; i < N - 1; i++)
    {
        int a, b;
        scanf("%d %d", &a, &b);
        map[a].push_back(b);
        map[b].push_back(a);
    }

    for (int i = 0; i < N; i++)
        scanf("%d", &apple[i]);

    printf("%d", BFS());

    return (0);
}
반응형