Submission #233750

#TimeUsernameProblemLanguageResultExecution timeMemory
233750dualityFire (JOI20_ho_t5)C++11
8 / 100
1092 ms9340 KiB
#include <bits/stdc++.h> using namespace std; #define mp make_pair #define pb push_back typedef long long int LLI; typedef vector<int> vi; typedef pair<int,int> pii; typedef vector<pii> vpii; #pragma GCC optimize("Ofast") #pragma GCC target("avx,avx2,fma") int S[200000]; LLI pre[200001]; struct query { int T,L,R,i; }; bool comp(query a,query b) { return a.T < b.T; } query queries[200000]; LLI ans[200000]; int main() { int i; int N,Q,T,L,R; scanf("%d %d",&N,&Q); for (i = 0; i < N; i++) scanf("%d",&S[i]); for (i = 0; i < Q; i++) { scanf("%d %d %d",&T,&L,&R); queries[i] = (query){T+1,L-1,R-1,i}; } sort(queries,queries+Q,comp); int j,c = 1; for (i = 0; i < Q; i++) { while (queries[i].T >= 2*c) { for (j = N-1; j >= c; j--) S[j] = max(S[j],S[j-c]); for (j = 0; j < N; j++) pre[j+1] = pre[j]+S[j]; c *= 2; } LLI a = 0; int d = queries[i].T-c; if (d > queries[i].L) a += pre[min(d,queries[i].R+1)]-pre[queries[i].L]; int e = max(d,queries[i].L); if (e <= queries[i].R) { int *p = S+e,*q = S+(e-d); int t = queries[i].R-e+1; for (j = 0; j < t; j++) { a += (*p > *q) ? *p:*q; p++,q++; } //for (j = e; j <= queries[i].R; j++) a += max(S[j],S[j-d]); } ans[queries[i].i] = a; } for (i = 0; i < Q; i++) printf("%lld\n",ans[i]); return 0; }

Compilation message (stderr)

ho_t5.cpp: In function 'int main()':
ho_t5.cpp:23:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d %d",&N,&Q);
     ~~~~~^~~~~~~~~~~~~~~
ho_t5.cpp:24:34: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     for (i = 0; i < N; i++) scanf("%d",&S[i]);
                             ~~~~~^~~~~~~~~~~~
ho_t5.cpp:26:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d %d %d",&T,&L,&R);
         ~~~~~^~~~~~~~~~~~~~~~~~~~~
#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...