제출 #150984

#제출 시각아이디문제언어결과실행 시간메모리
150984osaaateiasavtnl비밀 (JOI14_secret)C++14
0 / 100
610 ms8628 KiB
#include<bits/stdc++.h> #include "secret.h" using namespace std; #define ii pair <int, int> #define app push_back #define all(a) a.begin(), a.end() #define bp __builtin_popcount #define ll long long #define mp make_pair #define f first #define s second const int N = 1001; int mem[N][N], memn; void prec(int l, int r) { if (l == r) return; int m = (l + r) >> 1; prec(l, m); prec(m + 1, r); for (int i = m - 1; i >= l; --i) mem[i][m] = Secret(mem[i][i], mem[i + 1][m]); for (int i = m + 2; i <= r; ++i) mem[m][i] = Secret(mem[m + 1][i - 1], mem[i][i]); } void Init(int n, int a[]) { for (int i = 1; i <= n; ++i) mem[i][i] = a[i]; prec(1, n); memn = n; } int get(int tl, int tr, int l, int r) { if (tl == tr) return mem[tl][tl]; int tm = (tl + tr) >> 1; if (r <= tm) return get(tl, tm, l, r); if (tm < l) return get(tm + 1, tr, l, r); return Secret(mem[l][tm], mem[tm + 1][r]); } int Query(int l, int r) { return get(1, memn, l, r); }
#Verdict Execution timeMemoryGrader output
Fetching results...