This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int NMAX=2007;
int n,a,b;
int dp[NMAX];
int dp1[105][105];
ll y[NMAX],parc[NMAX];
int main()
{
ios_base::sync_with_stdio(false);
cin>>n>>a>>b;
for(int i=0;i<n;i++) cin>>y[i];
parc[0]=y[0];
for(int i=1;i<n;i++) parc[i]=parc[i-1]+y[i];
if(a==1)
{
ll res=0;
for(int i=40;i>=0;i--)
{
ll cur=res | (1ll<<i);
for(int j=0;j<=n;j++) dp[j]=n+1;
dp[0]=0;
for(int j=0;j<n;j++)
{
ll sum=0;
for(int k=j;k<n;k++)
{
sum+=y[k];
if((sum&cur)==0) dp[k+1]=min(dp[k+1],dp[j]+1);
}
}
if(dp[n]<=b) res+=(1ll<<i);
}
cout<<(1ll<<41)-1-res<<endl;
}
else
{
ll res=0;
for(int i=40;i>=0;i--)
{
ll cur=res|(1ll<<i);
memset(dp1,0,sizeof(dp1));
for(int t=0;t<n;t++) if((cur&parc[t])==0) dp1[t][1]=1;
for(int t=2;t<=n;t++)
{
for(int j=0;j<n;j++)
{
ll sum=0;
for(int k=j;k<n;k++)
{
sum+=y[k];
if((cur&sum)==0 && dp1[j][t-1]) dp1[k][t]=1;
}
}
}
for(int t=a;t<=b;t++)
{
if(dp1[n-1][t])
{
res+=(1ll<<i);
break;
}
}
}
cout<<(1ll<<41)-1-res<<endl;
}
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... |