BZOJ 2216 Lightning Conductor

Posted ziliuziliu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BZOJ 2216 Lightning Conductor相关的知识,希望对你有一定的参考价值。

决策单调。整体二分。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
#define maxn 500500
using namespace std;
int n,a[maxn],f[maxn],g[maxn];
void dp1(int left,int right,int l,int r)
{
    if (left>right) return;
    int mid=left+right>>1;
    int pos;double mx=0;
    for (int i=l;i<=r && i<=mid;i++)
    {
        if ((double)a[i]+sqrt(mid-i)>mx)
        {
            mx=(double)a[i]+sqrt(mid-i);
            pos=i;
        }
    }
    f[mid]=a[pos]+ceil(sqrt(mid-pos));
    dp1(left,mid-1,l,pos);dp1(mid+1,right,pos,r);
}
void dp2(int left,int right,int l,int r)
{
    if (left>right) return;
    int mid=left+right>>1;
    int pos;double mx=0;
    for (int i=r;i>=l && i>=mid;i--)
    {
        if ((double)a[i]+sqrt(i-mid)>mx)
        {
            mx=(double)a[i]+sqrt(i-mid);
            pos=i;
        }
    }
    g[mid]=a[pos]+ceil(sqrt(pos-mid));
    dp2(left,mid-1,l,pos);dp2(mid+1,right,pos,r);
}
int main()
{
    scanf("%d",&n);
    for (int i=1;i<=n;i++)
        scanf("%d",&a[i]);
    dp1(1,n,1,n);dp2(1,n,1,n);
    for (int i=1;i<=n;i++)
        printf("%d\n",max(f[i],g[i])-a[i]);
    return 0;
}

 

以上是关于BZOJ 2216 Lightning Conductor的主要内容,如果未能解决你的问题,请参考以下文章

BZOJ2216[Poi2011]Lightning Conductor 决策单调性

bzoj2216: [Poi2011]Lightning Conductor(分治决策单调性优化)

[决策单调性][整体二分] Bzoj P2216 Lightning Conductor

bzoj 2216 [Poi2011]Lightning Conductor 决策单调性+dp

bzoj2216[Poi2011]Lightning Conductor 1D1D动态规划优化

是否可以使用 PyTorch Lightning Bolts 在实例分割任务上微调 SimCLR?