제출 #687356

#제출 시각아이디문제언어결과실행 시간메모리
687356Bliznetc동굴 (IOI13_cave)C++17
컴파일 에러
0 ms0 KiB
//#include "cave.h" #include <bits/stdc++.h> #include <stdlib.h> #include <stdio.h> using namespace std; #define pb push_back #define sz size() #define all(x) x.begin(), x.end() #define F first #define S second #define MAX_N 5000 #define MAX_CALLS 70000 typedef pair < int, int > pii; typedef vector < int > vi; typedef vector < vi > vvi; /*int N; static int realS[MAX_N]; static int realD[MAX_N]; static int inv[MAX_N]; static int num_calls; void answer(int S[], int D[]) { int i; int correct = 1; for (i = 0; i < N; ++i) if (S[i] != realS[i] || D[i] != realD[i]) { correct = 0; break; } if (correct) printf("CORRECT\n"); else printf("INCORRECT\n"); for (i = 0; i < N; ++i) { if (i > 0) printf(" "); printf("%d", S[i]); } printf("\n"); for (i = 0; i < N; ++i) { if (i > 0) printf(" "); printf("%d", D[i]); } printf("\n"); exit(0); } int tryCombination(int S[]) { int i; // for (i = 0; i < N; i++) { // cout << S[i] << " "; // } // cout << "\n"; if (num_calls >= MAX_CALLS) { printf("INCORRECT\nToo many calls to tryCombination().\n"); exit(0); } ++num_calls; for (i = 0; i < N; ++i) if (S[inv[i]] != realS[inv[i]]) return i; return -1; } int init() { int i, res; FILE *f = fopen("cave.in", "r"); /*if (!f) fail("Failed to open input file.");*/ res = fscanf(f, "%d", &N); for (i = 0; i < N; ++i) { res = fscanf(f, "%d", &realS[i]); } for (i = 0; i < N; ++i) { res = fscanf(f, "%d", &realD[i]); inv[realD[i]] = i; } num_calls = 0; return N; }*/ void exploreCave (int n) { int ask[n]; int good[n]; int d[n]; for (int i = 0; i < n; i++) { good[i] = d[i] = -1; } // vector<int> good(n, -1), d(n, -1); for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { if (good[j] == -1) { ask[j] = 0; } else { ask[j] = good[j]; } } int x = tryCombination(ask); if (x == i) { for (int j = 0; j < n; j++) { if (good[j] == -1) { ask[j] = 1; } else { ask[j] = good[j]; } } } int l = 0, r = n - 1; while (r - l > 0) { int mid = (l + r) / 2; for (int j = l; j <= mid; j++) { if (good[j] == -1) { ask[j] = 1 - ask[j]; } else { ask[j] = good[j]; } } x = tryCombination(ask); // cout << i << " - " << x << " " << l << " " << r << "\n"; if (x == i) { for (int j = l; j <= mid; j++) { if (good[j] == -1) { ask[j] = 1 - ask[j]; } else { ask[j] = good[j]; } } for (int j = mid + 1; j <= r; j++) { if (good[j] == -1) { ask[j] = 1 - ask[j]; } else { ask[j] = good[j]; } } r = mid; } else { l = mid + 1; } // cout << l << " " << r << ":\n"; // for (int j = 0; j < n; j++) { // cout << ask[j] << " "; // } // cout << "\n"; } if (good[l] == -1) { ask[l] = 1 - ask[l]; } else { ask[l] = good[l]; } x = tryCombination(ask); if (x == i) { if (good[l] == -1) { ask[l] = 1 - ask[l]; } else { ask[l] = good[l]; } l = r; } good[l] = ask[l]; d[l] = i; // cout << i << " - " << l << " " << good[i] << " " << d[l] << "\n"; // cout << "\n"; } answer(good, d); } /* int main() { int N; N = init(); exploreCave(N); printf("INCORRECT\nYour solution did not call answer().\n"); return 0; }*/ /* signed main() { vi a; a.pb(-2); a.pb(2); a.pb(2); a.pb(-2); a.pb(-2); a.pb(2); cout << count_swaps(a); } */

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

cave.cpp:81:5: warning: "/*" within comment [-Wcomment]
   81 |     /*if (!f)
      |      
cave.cpp:84:5: error: 'res' does not name a type
   84 |     res = fscanf(f, "%d", &N);
      |     ^~~
cave.cpp:86:5: error: expected unqualified-id before 'for'
   86 |     for (i = 0; i < N; ++i) {
      |     ^~~
cave.cpp:86:17: error: 'i' does not name a type; did you mean 'vi'?
   86 |     for (i = 0; i < N; ++i) {
      |                 ^
      |                 vi
cave.cpp:86:24: error: expected unqualified-id before '++' token
   86 |     for (i = 0; i < N; ++i) {
      |                        ^~
cave.cpp:89:5: error: expected unqualified-id before 'for'
   89 |     for (i = 0; i < N; ++i) {
      |     ^~~
cave.cpp:89:17: error: 'i' does not name a type; did you mean 'vi'?
   89 |     for (i = 0; i < N; ++i) {
      |                 ^
      |                 vi
cave.cpp:89:24: error: expected unqualified-id before '++' token
   89 |     for (i = 0; i < N; ++i) {
      |                        ^~
cave.cpp:94:5: error: 'num_calls' does not name a type
   94 |     num_calls = 0;
      |     ^~~~~~~~~
cave.cpp:95:5: error: expected unqualified-id before 'return'
   95 |     return N;
      |     ^~~~~~
cave.cpp:96:1: error: expected declaration before '}' token
   96 | }*/
      | ^
cave.cpp:96:3: error: expected unqualified-id before '/' token
   96 | }*/
      |   ^