思维题bzoj原题。。。
枚举每个点补充,把每个点的左前缀和右前缀的大于它减小于它的差的情况都搞出来就行了不超时。。。
为什么感觉百度之星第二场比第一场题更适合我然而。。。都是天意啊
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define MAXN 17005
#define MID 8100
using namespace std;
int l[MAXN],r[MAXN];
int a[MAXN],MAX,n;
int main()
{
while(scanf("%d",&n)!=EOF)
{
for(int i=0;i<n;i++)
scanf("%d",&a[i]);
for(int i=0;i<n;i++)
{
int ans = 0;
int pre = 0;
l[pre+MID] = 1;
int ma = 0;
for(int j=i-1;j>=0;j--)
{
pre+=(a[j]>a[i]?1:-1);
l[pre+MID]++;
ma = max(ma,abs(pre));
}
pre = 0;
r[pre+MID] = 1;
for(int j=i+1;j<n;j++)
{
pre+=(a[j]>a[i]?1:-1);
r[pre+MID]++;
ma = max(ma,abs(pre));
}
ans+=l[MID]*r[MID];
l[MID] = 0;
r[MID] = 0;
for(int j=1;j<=ma;j++)
{
ans+=l[MID-j]*r[MID+j];
ans+=l[MID+j]*r[MID-j];
l[j+MID] = 0;
r[MID-j] = 0;
l[MID-j] = 0;
r[MID+j] = 0;
}
printf("%d%c",ans,i==n-1?'\n':' ');
}
}
return 0;
}