This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
using namespace std;
constexpr int mod = 1000000007;
void mpl(int &x,int y) {
x += y;
if(x >= mod) x -= mod;
}
struct UnionFind {
vector<int>par,size,sum;
UnionFind(int n,vector<int>w) {
par.resize(n);
size.resize(n);
sum.resize(n);
for(int i = 0; i < n; i++) {
par[i] = i;
sum[i] = w[i];
}
}
int find(int x) {
if(par[x] == x) {
return x;
}
return par[x] = find(par[x]);
}
void unite(int u,int v) {
u = find(u);
v = find(v);
if(u == v) {
return;
}
if(size[u] > size[v]) swap(u,v);
size[v] += size[u];
mpl(sum[v],sum[u]);
par[u] = v;
}
int consum(int x) {
return sum[find(x)];
}
};
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int N;
cin >> N;
vector<int>h(N),w(N),cmp;
for(int i = 0; i < N; i++) {
cin >> h[i];
cmp.push_back(h[i]);
}
for(int i = 0; i < N; i++) {
cin >> w[i];
}
cmp.push_back(0);
sort(cmp.begin(),cmp.end());
cmp.erase(unique(cmp.begin(),cmp.end()),cmp.end());
vector<vector<int>>tmp(cmp.size());
for(int i = 0; i < N; i++) {
h[i] = lower_bound(cmp.begin(),cmp.end(),h[i])-cmp.begin();
tmp[h[i]].push_back(i);
}
UnionFind uf(N,w);
int ans = 0,sum = 0;
for(int i = cmp.size()-1; i >= 1; i--) {
for(int j = 0; j < tmp[i].size(); j++) {
mpl(sum,1ll*(1+w[tmp[i][j]])*(w[tmp[i][j]])/2%mod);
if(tmp[i][j] && h[tmp[i][j]-1] >= h[tmp[i][j]]) {
int sum1 = uf.consum(tmp[i][j]-1);
int sum2 = uf.consum(tmp[i][j]);
uf.unite(tmp[i][j]-1,tmp[i][j]);
mpl(sum,1ll*sum1*sum2%mod);
}
if(tmp[i][j]+1 < N && h[tmp[i][j]+1] > h[tmp[i][j]]) {
int sum1 = uf.consum(tmp[i][j]);
int sum2 = uf.consum(tmp[i][j]+1);
uf.unite(tmp[i][j],tmp[i][j]+1);
mpl(sum,1ll*sum1*sum2%mod);
}
}
int res = 1ll*(1+cmp[i])*cmp[i]/2%mod;
mpl(res,mod-1ll*(1+cmp[i-1])*cmp[i-1]/2%mod);
mpl(ans,1ll*res*sum%mod);
}
cout << ans << "\n";
}
Compilation message (stderr)
fancyfence.cpp: In function 'int main()':
fancyfence.cpp:68:26: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
68 | for(int j = 0; j < tmp[i].size(); j++) {
| ~~^~~~~~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |