Submission #577527

#TimeUsernameProblemLanguageResultExecution timeMemory
577527amunduzbaevFancy Fence (CEOI20_fancyfence)C++17
12 / 100
6 ms388 KiB
#include "bits/stdc++.h" using namespace std; #define ar array typedef int64_t ll; #define int ll const int N = 1e5 + 5; const int mod = 1e9 + 7; int h[N], w[N], pref[N]; int l[N], r[N]; signed main(){ ios::sync_with_stdio(0); cin.tie(0); int n; cin>>n; for(int i=1;i<=n;i++){ cin>>h[i]; } for(int i=1;i<=n;i++){ cin>>w[i]; pref[i] = pref[i-1] + w[i]; } vector<int> ss; for(int i=1;i<=n;i++){ while(!ss.empty() && h[ss.back()] > h[i]){ ss.pop_back(); } if(!ss.empty()) l[i] = ss.back(); else l[i] = 0; ss.push_back(i); } ss.clear(); for(int i=n;i>0;i--){ while(!ss.empty() && h[ss.back()] >= h[i]){ ss.pop_back(); } if(!ss.empty()) r[i] = ss.back(); else r[i] = n + 1; } int inv = 5e8 + 4; int res = 0; //~ for(int i=1;i<=n;i++){ //~ int L = (pref[i-1] - pref[l[i]]) % mod, R = (pref[r[i]-1] - pref[i]) % mod; //~ int T = (pref[r[i] - 1] - pref[l[i]]) % mod; //~ int tot = (T * 1ll * (T + 1) % mod - L * 1ll * (L + 1) % mod - R * 1ll * (R + 1) % mod + mod + mod) % mod; //~ tot = tot * 1ll * inv % mod; //~ T = h[i] * 1ll * (h[i] + 1) / 2 % mod; //~ res = (res + tot * 1ll * T) % mod; //~ } for(int i=1;i<=n;i++){ int mn = h[i]; for(int j=i+1;j<=n;j++){ mn = min(mn, h[j]); int t = mn * 1ll * (mn + 1) / 2 % mod; res = (res + t * 1ll * w[i] % mod * w[j]) % mod; } int W = w[i] * 1ll * (w[i] + 1) / 2 % mod; int H = h[i] * 1ll * (h[i] + 1) / 2 % mod; res = (res + W * 1ll * H % mod); } cout<<res<<"\n"; }

Compilation message (stderr)

fancyfence.cpp: In function 'int main()':
fancyfence.cpp:45:6: warning: unused variable 'inv' [-Wunused-variable]
   45 |  int inv = 5e8 + 4;
      |      ^~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...