이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define FOR(i, a, b) for (int i = (a); i < (b); i++)
#define REP(i, n) FOR(i, 0, n)
#define ll long long
using namespace std;
const int MAXN = 2010;
ll arr[MAXN];
int n, a, b;
namespace code1 {
ll dp[MAXN][MAXN];
ll pref[MAXN];
void solve() {
REP(i, n) {
pref[i] = arr[i];
if (i) pref[i] += pref[i - 1];
}
REP(i, n) {
dp[i][1] = pref[i];
FOR(j, 2, n) {
dp[i][j] = (1LL << 60);
REP(k, i) {
dp[i][j] = min(dp[i][j], (dp[k][j - 1] | (pref[i] - pref[k])));
}
}
}
ll out = (1LL << 60);
FOR(i, a, b + 1) out = min(out, dp[n - 1][i]);
cout << out << "\n";
return;
}
};
int main() {
ios_base::sync_with_stdio(false);
cin >> n >> a >> b;
REP(i, n) cin >> arr[i];
code1::solve();
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |