Submission #256574

#TimeUsernameProblemLanguageResultExecution timeMemory
256574ElyesChaabouniVudu (COCI15_vudu)C++17
112 / 140
1095 ms65540 KiB
#pragma GCC optimize("O3") #pragma GCC target ("avx2") #pragma GCC optimization ("O3") #pragma GCC optimization ("unroll-loops") #include<bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> // Common file #include <ext/pb_ds/tree_policy.hpp> // Including tree_order_statistics_node_update#define eps 1e-9 #define MOD1 998244353 #define MOD2 1000000007 #define INV_10 299473306 #define INF 1000000001 #define PI 3.14159265358979323846 #define ordered_set tree<pair<long long, int>, null_type,less<pair<long long, int> >, rb_tree_tag,tree_order_statistics_node_update> using namespace std; using namespace __gnu_pbds; int main() { ios::sync_with_stdio(0);cin.tie(0);cout.tie(0); int n; //cin >> n; scanf("%d", &n); int a[n]; ordered_set s; //cout << n << '\n'; for(int i = 0; i < n; i++) scanf("%d", &a[i]); //cin >> a[i]; int p; scanf("%d", &p); //cin >> p; long long sum=0, cu=0, ans=0; for(int i = n-1; i >= 0; i--) { sum+=a[i]; s.insert(make_pair(sum-cu, i)); //cout << here[i] << ' '; cu+=p; } //cout << '\n'; cu=0; sum=0; for(int i = n-1; i >= 0; i--) { ordered_set::iterator it=s.lower_bound(make_pair(p+sum-cu, -1)); if(it!=s.end()) ans+=i+1-s.order_of_key(*it); //cout << s.order_of_key(*s.lower_bound(make_pair(p+pr-cu, -1))) << '\n'; sum+=a[i]; s.erase(make_pair(sum-cu, i)); cu+=p; } //cout << ans << '\n'; printf("%lld", ans); }

Compilation message (stderr)

vudu.cpp:3:0: warning: ignoring #pragma GCC optimization [-Wunknown-pragmas]
 #pragma GCC optimization ("O3")
 
vudu.cpp:4:0: warning: ignoring #pragma GCC optimization [-Wunknown-pragmas]
 #pragma GCC optimization ("unroll-loops")
 
vudu.cpp: In function 'int main()':
vudu.cpp:21:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d", &n);
  ~~~~~^~~~~~~~~~
vudu.cpp:26:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d", &a[i]);
   ~~~~~^~~~~~~~~~~~~
vudu.cpp:29:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d", &p);
  ~~~~~^~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...