这个题目是一道dp题。
可以将金字塔的“一上一下”拆开考虑,最后合并。
以下分析“一上”的情况:
#include<bits/stdc++.h>
using namespace std;
int n;
int a[200010];
int f[200010];
int g[200010];
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>a[i];
}
for(int i=1;i<=n;i++)
{
f[i]=min(f[i-1]+1,a[i]);//dp
}
for(int i=n;i>=1;i--)
{
g[i]=min(g[i+1]+1,a[i]);
}
int ans=0;
for(int i=1;i<=n;i++)
{
ans = max(min(f[i],g[i]),ans);
}
cout<<ans;
return 0;
}