제출 #95288

#제출 시각아이디문제언어결과실행 시간메모리
95288dalgerok비밀 (JOI14_secret)C++14
100 / 100
507 ms9504 KiB
#include "secret.h"
#include<bits/stdc++.h>
using namespace std;



const int N = 1005;


int n, a[N], dp[N][N];
bool used[N][N];

void rec(int l, int r){
    if(l == r){
        return;
    }
    if(l + 1 == r){
        return;
    }
    int mid = (r + l) >> 1;
    dp[mid][mid] = a[mid];
    dp[mid + 1][mid + 1] = a[mid + 1];
    for(int i = mid + 2; i <= r; i++){
        if(!used[mid + 1][i]){
            used[mid + 1][i] = true;
            dp[mid + 1][i] = Secret(dp[mid + 1][i - 1], a[i]);
        }
    }
    for(int i = mid - 1; i >= l; i--){
        if(!used[i][mid]){
            used[i][mid] = true;
            dp[i][mid] = Secret(a[i], dp[i + 1][mid]);
        }
    }
    rec(l, mid);
    rec(mid + 1, r);
}

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

int Query(int L, int R){
    if(L == R){
        return a[L];
    }
    if(L + 1 == R){
        return Secret(a[L], a[R]);
    }
    int l = 0, r = n - 1;
    while(r - l > 1){
        int mid = (r + l) >> 1;
        if(L <= mid && mid + 1 <= R){
            return Secret(dp[L][mid], dp[mid + 1][R]);
        }
        if(R <= mid){
            r = mid;
        }
        else{
            l = mid + 1;
        }
    }
}

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

secret.cpp: In function 'int Query(int, int)':
secret.cpp:67:1: warning: control reaches end of non-void function [-Wreturn-type]
 }
 ^
#Verdict Execution timeMemoryGrader output
Fetching results...