Submission #1305592

#TimeUsernameProblemLanguageResultExecution timeMemory
1305592ulvixBali Sculptures (APIO15_sculpture)C++20
100 / 100
162 ms660 KiB
// #pragma GCC optimize("O3,unroll-loops") // #pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt") #include <bits/stdc++.h> #ifdef ULVI #include "debug.hpp" #else #define db(...) #define dbv(v) #define line() #endif #include <ext/pb_ds/assoc_container.hpp> #include <ext/pb_ds/tree_policy.hpp> #define all(x) x.begin(),x.end() #define rall(x) x.rbegin(),x.rend() #define ff first #define ss second #define enld endl using namespace std; using namespace __gnu_pbds; typedef long long ll; typedef pair<ll,ll> pll; const ll sz=2e5+100; const ll mod=1e9+7; const ll inf=1ll<<62; template<class T> using indexed_set=tree<T,null_type,less<T>,rb_tree_tag,tree_order_statistics_node_update>; mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count()); ll n,l,r; vector<ll> v(2100),pref(2100); vector<vector<ll>> dp1(110,vector<ll>(110)); vector<ll> dp2(2100); ll f1(ll mask){ dp1.assign(n+5,vector<ll>(r+5)); dp1[0][0]=1; for(ll i=1;i<=n;i++){ for(ll j=1;j<=min(i,r);j++){ for(ll k=j-1;k<i;k++){ if(dp1[k][j-1] && !((pref[i]-pref[k])&~mask)){ dp1[i][j]=1; break; } } } } for(ll i=l;i<=r;i++) if(dp1[n][i]) return 1; return 0; } ll f2(ll mask){ dp2.assign(n+5,inf); dp2[0]=0; for(ll i=1;i<=n;i++){ for(ll j=0;j<i;j++) if(!((pref[i]-pref[j])&~mask)) dp2[i]=min(dp2[i],dp2[j]+1); } return l<=dp2[n] && dp2[n]<=r; } ll f(ll mask){ return (l==1?f2(mask):f1(mask)); } void solve(){ cin>>n>>l>>r; for(ll i=1;i<=n;i++){ cin>>v[i]; pref[i]=pref[i-1]+v[i]; } ll ans=(1ll<<61)-1; for(ll i=1ll<<60;i;i>>=1) if(f(ans&~i)) ans&=~i; cout<<ans<<'\n'; } int main(){ // freopen("input.txt","r",stdin); // freopen("output.txt","w",stdout); ios_base::sync_with_stdio(0); cin.tie(0); ll t=1; // cin>>t; for(ll _=1;_<=t;_++){ // cout<<"Scenario #"<<_<<":\n"; solve(); } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...