제출 #1221334

#제출 시각아이디문제언어결과실행 시간메모리
1221334im2xtremeBeech Tree (IOI23_beechtree)C++20
컴파일 에러
0 ms0 KiB
#include <iostream> #include <vector> #include <unordered_map> #include "beechtree.h" using namespace std; const int MAXN = 200005; vector<int> tree[MAXN]; int result[MAXN]; void collect_subtree(int u, vector<int>& nodes) { nodes.push_back(u); for (int v : tree[u]) { collect_subtree(v, nodes); } } bool is_beautiful(const vector<int>& P, const vector<int>& C, int root) { vector<int> nodes; collect_subtree(root, nodes); if (nodes[0] != root) return false; unordered_map<int, int> color_count; for (int i = 1; i < (int)nodes.size(); ++i) { int curr = nodes[i]; int color = C[curr]; int f = color_count[color]; if (f >= i || P[curr] != nodes[f]) return false; color_count[color]++; } return true; } int* beechtree(int N, int M, vector<int> P, vector<int> C) { for (int i = 0; i < N; ++i) { tree[i].clear(); } for (int i = 1; i < N; ++i) { tree[P[i]].push_back(i); } for (int i = 0; i < N; ++i) { result[i] = is_beautiful(P, C, i) ? 1 : 0; } return result; }

컴파일 시 표준 에러 (stderr) 메시지

beechtree.cpp:40:6: error: ambiguating new declaration of 'int* beechtree(int, int, std::vector<int>, std::vector<int>)'
   40 | int* beechtree(int N, int M, vector<int> P, vector<int> C) {
      |      ^~~~~~~~~
In file included from beechtree.cpp:4:
beechtree.h:3:18: note: old declaration 'std::vector<int> beechtree(int, int, std::vector<int>, std::vector<int>)'
    3 | std::vector<int> beechtree(int N, int M, std::vector<int> P, std::vector<int> C);
      |                  ^~~~~~~~~