Submission #321635

#TimeUsernameProblemLanguageResultExecution timeMemory
321635Kenzo_1114Secret (JOI14_secret)C++17
0 / 100
500 ms8428 KiB
#include<bits/stdc++.h>
#include "secret.h"
using namespace std;
const int MAXN = 1010;

int N, ans[MAXN][MAXN];

void divide_and_conquer(int l, int r)
{
	if(r - l <= 1)	return;
	
	int mid = (l + r) >> 1;

	for(int i = mid - 1; l <= i; i--)	ans[i][mid] = Secret(ans[i][i], ans[i + 1][mid]);
	for(int i = mid + 2; i <= r; i++)	ans[mid][i] = Secret(ans[mid][i - 1], ans[i][i]);

	divide_and_conquer(l, mid);
	divide_and_conquer(mid + 1, r);	
}

void Init(int n, int a[])
{
	N = n;
	for(int i = 0; i < n; i++)	ans[i][i] = a[i];
	divide_and_conquer(0, N - 1);
}

int findAns(int l, int r, int L, int R)
{
	int mid = (l + r) >> 1;

	if(L <= mid && mid + 1 <= R)	return Secret(ans[L][mid], ans[mid + 1][R]);
	if(R <= mid)	return findAns(l, mid, L, R);
	else			return findAns(mid + 1, r, L, R);
}

int Query(int l, int r)
{
	if(r - l <= 1)	return Secret(ans[l][l], ans[r][r]);
	return findAns(0, N - 1, l, r);
}
#Verdict Execution timeMemoryGrader output
Fetching results...