标签:ch NOIP int 31 mx num rm ri define
题解 \(by\;zj\varphi\)
考虑如何才能最优。
每次一定把当前最小值移动到边界上,那么看它向左还是向右移更优。
用树状数组维护一下即可,复杂度 \(\mathcal O\rm (nlogn)\)
Code
#include<bits/stdc++.h>
#define ri register signed
#define p(i) ++i
namespace IO{
char buf[1<<21],*p1=buf,*p2=buf;
#define gc() p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?(-1):*p1++
struct nanfeng_stream{
template<typename T>inline nanfeng_stream &operator>>(T &x) {
ri f=1;x=0;register char ch=gc();
while(!isdigit(ch)) {if (ch=='-') f=0;ch=gc();}
while(isdigit(ch)) {x=(x<<1)+(x<<3)+(ch^48);ch=gc();}
return x=f?x:-x,*this;
}
}cin;
}
using IO::cin;
namespace nanfeng{
#define FI FILE *IN
#define FO FILE *OUT
template<typename T>inline T cmax(T x,T y) {return x>y?x:y;}
template<typename T>inline T cmin(T x,T y) {return x>y?y:x;}
typedef long long ll;
static const int N=1e5+7;
int *a[N],vis[N],num[N],l[N],r[N],mx,n;
ll ans;
struct BIT{
#define lowbit(x) ((x)&-(x))
int c[N];
inline void update(int x,int k) {for (ri i(x);i<=n;i+=lowbit(i)) c[i]+=k;}
inline int query(int x) {
int res(0);
for (ri i(x);i;i-=lowbit(i)) res+=c[i];
return res;
}
}B;
inline int main() {
//FI=freopen("nanfeng.in","r",stdin);
//FO=freopen("nanfeng.out","w",stdout);
cin >> n;
for (ri i(1);i<=n;p(i)) cin >> num[i],p(vis[num[i]]),mx=cmax(mx,num[i]);
for (ri i(1);i<=mx;p(i)) {
if (!vis[i]) continue;
a[i]=new int[vis[i]+1];
l[i]=1;
}
for (ri i(1);i<=n;p(i)) a[num[i]][p(r[num[i]])]=i,B.update(i,1);
for (ri i(1);i<=mx;p(i)) {
if (!vis[i]) continue;
while(l[i]<=r[i]) {
int x1=a[i][l[i]],x2=a[i][r[i]];
int d1=B.query(x1-1),d2=B.query(n)-B.query(x2);
if (d1<d2) {
ans+=d1;
B.update(x1,-1);
p(l[i]);
} else {
ans+=d2;
B.update(x2,-1);
--r[i];
}
//printf("ans=%lld\n",ans);
}
}
printf("%lld\n",ans);
return 0;
}
}
int main() {return nanfeng::main();}
标签:ch,NOIP,int,31,mx,num,rm,ri,define 来源: https://www.cnblogs.com/nanfeng-blog/p/15110937.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。