제출 #1203728

#제출 시각아이디문제언어결과실행 시간메모리
1203728yonatanlSeptember (APIO24_september)C++20
컴파일 에러
0 ms0 KiB
//#include "september.h" #include <iostream> #include <algorithm> #include <vector> #include <set> #include <map> #define rep(i, s, e) for (ll i = s; i < e; i++) #define upmax(a, b) a = max(a, b) #define upmin(a, b) a = min(a, b) using namespace std; using ll = long long; using vll = vector<ll>; using vvll = vector<vll>; vvll tree; void dfs(ll node, ll papa, vll& dp, map<ll, ll>& idx) { for (auto& nei : tree[node]) { if (nei == papa) continue; dfs(nei, node, dp, idx); upmax(dp[node], dp[nei]); //upmax(dp[node], idx[nei]); } } int solve(int N, int M, vector<int> F, vector<vector<int>> S) { ll n = N, m = M; tree.clear(); tree.resize(n); rep(i, 1, n) { tree[i].push_back(F[i]); tree[F[i]].push_back(i); } int ans = 0; rep(i, 0, m) { map<ll, ll> mp; // idx[x] = the index of x in the current array vll dp(n); //dp[Sn - 1] = n - 1; rep(j, 0, n - 1) { mp[S[i][j]] = j; dp[S[i][j]] = j; } dfs(0, -1, dp, mp); //rep(j, 0, n) cout << dp[j] << ' '; //cout << endl; vll arr(n - 1); rep(j, 0, n - 1) { arr[j] = dp[S[i][j]]; } //rep(j, 0, n - 1) cout << arr[j] << " "; //cout << endl; ll curEnd = arr[0]; rep(j, 0, n - 1) { upmax(curEnd, arr[j]); if (j == curEnd) { ans++; } if (j == n - 2 && j != curEnd) while (true); } } return ans; } int main() { ios_base::sync_with_stdio(false); cin.tie(0); ll N, M; cin >> N >> M; vector<int> F(N); F[0] = -1; vector<vector<int>> S(M, vector<int>(N - 1)); rep(i, 1, N) cin >> F[i]; rep(i, 0, M) { rep(j, 0, N - 1) { cin >> S[i][j]; } } cout << solve(N, M, F, S) << endl; } /* 9 1 0 0 2 2 4 4 4 1 8 4 6 3 7 2 5 1 3 1 0 0 2 1 5 1 0 0 1 1 3 1 2 4 10 1 3 0 0 2 3 5 3 6 5 4 7 6 9 8 5 1 2 3 */

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

/usr/bin/ld: /tmp/cclAbqKL.o: in function `main':
grader.cpp:(.text.startup+0x0): multiple definition of `main'; /tmp/ccQBB1Lg.o:september.cpp:(.text.startup+0x0): first defined here
collect2: error: ld returned 1 exit status