# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
104805 | 2019-04-09T09:39:05 Z | ekrem | Bali Sculptures (APIO15_sculpture) | C++ | 3 ms | 540 KB |
#include <bits/stdc++.h> #define st first #define nd second #define mp make_pair #define pb push_back #define inf 1000000007 #define N 1000005 using namespace std; typedef long long ll; ll n, X, y, ans, a[N], dp[N], dpp[105][105], pre[N]; bool bak(ll x){ for(int i = 1; i <= n; i++) dp[i] = inf; for(int i = 0; i < 105; i++) for(int j = 0; j < 105; j++) dpp[i][j] = 0; dpp[0][0] = 1; for(int i = 1; i <= n; i++) for(int j = 0; j < n; j++){ ll su = pre[i] - pre[j]; if(su - (x&su) == 0 ){ if(n <= 100){ for(int k = 1; k < i; k++) dpp[i][k] |= dpp[j][k - 1]; } dp[i] = min(dp[i], dp[j] + 1); } } if(n <= 100){ for(int i = X; i <= y; i++) if(dpp[n][i]) return 1; return 0; } // cout << x << " " << dpp[n] << endl; return dp[n] <= y; } int main() { // freopen("in.txt", "r", stdin); // freopen("out.txt", "w", stdout); scanf("%lld %lld %lld",&n ,&X ,&y); for(int i = 1; i <= n; i++){ scanf("%lld",a + i); pre[i] = pre[i - 1] + a[i]; } ans = (1ll<<45) - 1; for(int i = 44; i >= 0; i--){ if(bak(ans - (1ll<<i))){ // cout << ans << " " << i << endl; ans -= (1ll<<i); } } printf("%lld\n", ans); return 0; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 3 ms | 384 KB | Output is correct |
2 | Correct | 3 ms | 512 KB | Output is correct |
3 | Incorrect | 3 ms | 512 KB | Output isn't correct |
4 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 3 ms | 512 KB | Output is correct |
2 | Correct | 2 ms | 412 KB | Output is correct |
3 | Incorrect | 2 ms | 512 KB | Output isn't correct |
4 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 2 ms | 384 KB | Output is correct |
2 | Correct | 2 ms | 384 KB | Output is correct |
3 | Incorrect | 3 ms | 512 KB | Output isn't correct |
4 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 3 ms | 512 KB | Output is correct |
2 | Correct | 2 ms | 512 KB | Output is correct |
3 | Incorrect | 3 ms | 512 KB | Output isn't correct |
4 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 2 ms | 384 KB | Output is correct |
2 | Correct | 3 ms | 540 KB | Output is correct |
3 | Incorrect | 2 ms | 384 KB | Output isn't correct |
4 | Halted | 0 ms | 0 KB | - |