Submission #104783

#TimeUsernameProblemLanguageResultExecution timeMemory
104783ekremBali Sculptures (APIO15_sculpture)C++98
50 / 100
185 ms512 KiB
#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], pre[N]; bool bak(ll x){ for(int i = 1; i <= n; i++) dp[i] = inf; 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 ) dp[i] = min(dp[i], dp[j] + 1); } // cout << x << " " << dp[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 (stderr)

sculpture.cpp: In function 'int main()':
sculpture.cpp:30:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%lld %lld %lld",&n ,&x ,&y);
  ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
sculpture.cpp:32:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%lld",a + i);
   ~~~~~^~~~~~~~~~~~~~
#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...