Submission #1114461

#TimeUsernameProblemLanguageResultExecution timeMemory
1114461sunboiXylophone (JOI18_xylophone)C++17
Compilation error
0 ms0 KiB
#include <cstdio> #include <cstdlib> #include <iostream> #include <vector> using namespace std; #include "xylophone.h" static int A[5000]; void solve(int N){ int n = N; int i = 1, fin = n; while(i < fin){ int m = (i + fin) / 2; if (query(m, n) == n - 1){ i = m + 1; }else fin = m; } i--; int reference = i; vector<int> a(n + 1), vis(n + 1); int x = query(i, i + 1); a[i] = 1; a[i + 1] = x + 1; i += 2; vis[1] = = vis[x + 1] = 1; int last = x; for (; i <= n; i++){ int mn = min(a[i - 1], a[i - 2]); int uno = query(i - 1, i); if (a[i - 1] + uno > n) a[i] = a[i - 1] - uno; else if (a[i - 1] + uno < 1) a[i] = a[i - 1] + uno; else if (vis[a[i - 1] + uno]) a[i] = a[i - 1] - uno; else if (vis[a[i - 1] - uno]) a[i] = a[i - 1] + uno; else{ int dos = query(i - 2, i); if (dos > last){ if (dos == uno){ if (a[i - 1] == mn) a[i] = a[i - 1] + uno; else a[i] = a[i - 1] - uno; }else{ if (a[i - 2] == mn) a[i] = a[i - 2] + dos; else a[i] = a[i - 2] - dos; } }else{ if (a[i - 1] == mn) a[i] = a[i - 1] + uno; else a[i] = a[i - 1] - uno; } } vis[a[i]] = 1; last = uno; } i = reference; if (i > 1){ x = query(i - 1, i); a[i - 1] = 1 + x; vis[1 + x] = 1; last = x; i -= 2; for (; i >= 1; i--){ int mn = min(a[i + 1], a[i + 2]); int uno = query(i, i + 1); if (a[i + 1] + uno > n) a[i] = a[i + 1] - uno; else if (a[i + 1] + uno < 1) a[i] = a[i + 1] + uno; else if (vis[a[i + 1] + uno]) a[i] = a[i + 1] - uno; else if (vis[a[i + 1] - uno]) a[i] = a[i + 1] + uno; else{ int dos = query(i, i + 2); if (dos > last){ if (dos == uno){ if (a[i + 1] == mn) a[i] = a[i + 1] + uno; else a[i] = a[i + 1] - uno; }else{ if (a[i + 2] == mn) a[i] = a[i + 2] + dos; else a[i] = a[i + 2] - dos; } }else{ if (a[i + 1] == mn) a[i] = a[i + 1] + uno; else a[i] = a[i + 1] - uno; } } vis[a[i]] = 1; last = uno; } } for(int i = 1;i<=n;i++) answer(i, a[i]); return; }

Compilation message (stderr)

xylophone.cpp: In function 'void solve(int)':
xylophone.cpp:27:14: error: expected primary-expression before '=' token
   27 |     vis[1] = = vis[x + 1] = 1;
      |              ^
xylophone.cpp: At global scope:
xylophone.cpp:8:12: warning: 'A' defined but not used [-Wunused-variable]
    8 | static int A[5000];
      |            ^