# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
566076 | 2022-05-21T18:11:41 Z | SSRS | 비밀 (JOI14_secret) | C++14 | 432 ms | 4472 KB |
#include <bits/stdc++.h> #include "secret.h" using namespace std; template <typename T> struct disjoint_sparse_table{ function<T(T, T)> f; vector<T> A; vector<vector<T>> D; disjoint_sparse_table(){ } disjoint_sparse_table(vector<T> &A, function<T(T, T)> f): A(A), f(f){ int N = A.size(); int LOG = 32 - __builtin_clz(N - 1); D = vector<vector<T>>(LOG, vector<T>(N)); for (int i = 0; i < LOG; i++){ int d = 1 << i; for (int j = 0; j + d < N; j += d * 2){ D[i][j + d - 1] = A[j + d - 1]; for (int k = j + d - 2; k >= j; k--){ D[i][k] = f(A[k], D[i][k + 1]); } D[i][j + d] = A[j + d]; for (int k = j + d + 1; k < min(j + d * 2, N); k++){ D[i][k] = f(D[i][k - 1], A[k]); } } } } T query(int L, int R){ if (R - L == 1){ return A[L]; } else { R--; int b = 31 - __builtin_clz(R ^ L); return f(D[b][L], D[b][R]); } } }; disjoint_sparse_table<int> DST; void Init(int N, int A[]){ vector<int> A2(N); for (int i = 0; i < N; i++){ A2[i] = A[i]; } DST = disjoint_sparse_table<int>(A2, Secret); } int Query(int L, int R){ R++; return DST.query(L, R); }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 124 ms | 2312 KB | Output is correct - number of calls to Secret by Init = 3578, maximum number of calls to Secret by Query = 1 |
2 | Correct | 122 ms | 2352 KB | Output is correct - number of calls to Secret by Init = 3586, maximum number of calls to Secret by Query = 1 |
3 | Correct | 121 ms | 2384 KB | Output is correct - number of calls to Secret by Init = 4097, maximum number of calls to Secret by Query = 1 |
4 | Correct | 431 ms | 4320 KB | Output is correct - number of calls to Secret by Init = 7979, maximum number of calls to Secret by Query = 1 |
5 | Correct | 426 ms | 4328 KB | Output is correct - number of calls to Secret by Init = 7986, maximum number of calls to Secret by Query = 1 |
6 | Correct | 432 ms | 4324 KB | Output is correct - number of calls to Secret by Init = 7986, maximum number of calls to Secret by Query = 1 |
7 | Correct | 426 ms | 4320 KB | Output is correct - number of calls to Secret by Init = 7986, maximum number of calls to Secret by Query = 1 |
8 | Correct | 432 ms | 4424 KB | Output is correct - number of calls to Secret by Init = 7986, maximum number of calls to Secret by Query = 1 |
9 | Correct | 427 ms | 4472 KB | Output is correct - number of calls to Secret by Init = 7986, maximum number of calls to Secret by Query = 1 |
10 | Correct | 428 ms | 4220 KB | Output is correct - number of calls to Secret by Init = 7986, maximum number of calls to Secret by Query = 1 |